Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
public class Student {
private int id;
public int getId() {
return this.id;
}
public setId(int newId) {
this.id = newId;
}
}
Приведенный ниже код дает вам исключение с нулевым указателем.
public class School {
Student obj_Student;
public School() {
try {
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Поскольку вы используете Obj_Student
, но вы забыли инициализировать его, как в правильном коде, показанном ниже:
public class School {
Student obj_Student;
public School() {
try {
obj_Student = new Student();
obj_Student.setId(12);
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Следующее преобразование:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output method="text"/>
<xsl:template match="*">
<xsl:apply-templates select="@TEXT | node()"/>
</xsl:template>
<xsl:template match="node/@TEXT | text()">
<xsl:if test="normalize-space(.)">
<xsl:value-of select=
"concat(normalize-space(.), '
')"/>
</xsl:if>
<xsl:apply-templates />
</xsl:template>
</xsl:stylesheet>
при применении против этого XML-документа
<t> <node TEXT=" txt A "/> <node TEXT=" txt X"/> <node> <html> <p> txt Y </p> </html> </node> <node TEXT="txt B"/> </t>
приводит к требуемому результату:
txt
txt X
txt Y
txt B
Действительно отмечает использование стандартной функции XPath нормализовать-пространство () , который снимает изоляцию со всего продвижения и конечных пробелов и заменяет каждую последовательность других пробелов со всего одним пространством.
Вы, вероятно, хотите
<xsl:strip-space elements="node"/>
, объяснил здесь . И этот статья имеет намного больше деталей.