Exception in thread "main" java.lang.ClassCastException: com.sun.org.apache.xerces.internal.dom.Defe

1、解决异常

Exception in thread “main” java.lang.ClassCastException: com.sun.org.apache.xerces.internal.dom.DeferredTextImpl cannot be cast to org.w3c.dom.Element at ParseXMLDemo02.main(ParseXMLDemo02.java:37)

2、场景

使用DOM解析XML文档时出现如上异常。
需求:使用DOM读取手机收藏信息
XML文档:

<?xml version="1.0" encoding="UTF-8"?>
<PhoneInfo>
	<Brand name="华为">
		<Type name="U8650"/>
	</Brand>
	<Brand name="苹果">
		<Type name="iPhone4"/>
		<Type name="iPhone5"/>
	</Brand>
</PhoneInfo>

Java源代码:

import java.io.IOException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;


//演示:使用DOM从手机收藏信息中读取品牌和型号信息
public class ParseXMLDemo02 {
	public static void main(String[] args) {
		//得到DOM解析器的工厂实例
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
		
		try {
			//从DOM工厂获得DOM解析器
			DocumentBuilder builder = factory.newDocumentBuilder();
			//解析XML文档,得到一个Document对象,即DOM树
			Document document = builder.parse("src/收藏信息2.xml");
			//得到所有Brand节点列表信息
			NodeList brandList = document.getElementsByTagName("Brand");
			//循环Brand信息
			for(int i=0;i<brandList.getLength();i++){
				//获取第i个Brand元素信息
				Node brand = brandList.item(i);
				//获取第i个Brand元素的name属性的值
				Element element = (Element) brand;
				String brandName = element.getAttribute("name");
				//获取第i个Brand元素的所有子元素的name属性值
				NodeList types = element.getChildNodes();
				for(int j=0;j<types.getLength();j++){
					Element typeElement = (Element) types.item(j);//Type节点
					String typeName = typeElement.getAttribute("name");//获得手机型号
					System.out.println("手机:"+brandName+typeName);
				}
			}
		} catch (ParserConfigurationException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SAXException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

3、问题分析即及解决

1)原因:在xml文档中元素之间使用了空格符,在getChildNodes()的时候系统把空格当成了文本节点,所以在遍历ChildNodes的时候将文本节点强制转换成Element类型就会出错。
2)解决方法:
方法一:
所谓元素间使用了空格键,指的就是使用回车或者空格,注意-包括回车。解决办法就是修改XML文档,拿掉回车。

修改后的XML文档:

<?xml version="1.0" encoding="UTF-8"?>
<PhoneInfo>
	<Brand name="华为"><Type name="U8650"/></Brand>
	<Brand name="苹果"><Type name="iPhone4"/><Type name="iPhone5"/></Brand>
</PhoneInfo>

方法二:
每次通过item()方法提取Node对象后判断node.getNodeType()==Node.ELEMENT_NODE,即判断是否是元素节点。原理:Element对象代表XML文档中的标签元素,继承自Node,也是Node最主要的子对象。
将36行至40行代码做如下修改:

for(int j=0;j<types.getLength();j++){
	Node typeNode = types.item(j);
	if(typeNode.getNodeType()==Node.ELEMENT_NODE){
		String typeName = ((Element)typeNode.getAttribute("name");//获得手机型号
        System.out.println("手机:"+brandName+typeName);
    }
}

4、最终运行结果:

手机:华为U8650
手机:苹果iPhone4
手机:苹果iPhone5
  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 异常在主线程中发生:"main" java.lang.ClassCastException: 这个异常表示在Java程序中发生了一个类型转换错误。可能是因为试图将一个对象转换为不兼容的类型,或者试图将一个对象转换为其子类,但实际上该对象不是该子类的实例。需要检查代码并确保类型转换是正确的。 ### 回答2: 这是一个 Java 异常,通常表示一个对象被强制转换为另一种数据类型,但转换失败了。这种错误通常发生在试图将一个子类对象赋值给超类对象时。Java 中每个对象都是某个类的子类,因此在将子类对象赋值给超类对象时,如果没有显式强制转换,则会发生自动类型转换。但是,在运行时,该对象的类型仍然是子类,因此,在某些情况下,将其强制转换为超类可能会导致类型不匹配。在这种情况下,Java 将抛出 ClassCastException 异常。 例如,假设我们有一个 Animal 类和一个 Dog 类,Dog 类是 Animal 类的子类。如果我们创建了一个 Dog 对象,并试图将其强制转换为 Animal 对象,则在运行时可能会发生 ClassCastException。因为 Dog 对象的类型仍然是 Dog,而不是 Animal。 为了解决这个问题,我们应该确保在强制转换之前检查对象的类型。使用 instanceof 运算符可以判断对象是否是特定类的实例。如果是,我们可以安全地将其强制转换为该类的对象,否则会抛出异常。 总之,要避免 ClassCastException 异常,我们需要谨慎处理对象的类型,并始终检查类型转换是否安全。如果不确定,则应使用 instanceof 进行检查。 ### 回答3: Exception in thread "main" java.lang.ClassCastExceptionJava中常见的异常之一。它表示尝试将一个对象强制转换为不是该对象类型的子类时发生了错误。 在Java中,强制类型转换是将一种数据类型转换为另一种数据类型的过程。但是如果对象的实际类型与转换的类型不兼容,就会发生ClassCastException异常。 例如,假设有一个父类Animal和两个子类Cat和Dog。如果我们尝试将一个Cat对象强制转换为Dog对象,由于Cat不是Dog的子类,就会抛出ClassCastException异常。 另一个常见的情况是,尝试将一个对象强制转换为它本来不是的接口类型,这也会导致ClassCastException异常的抛出。例如,如果我们尝试将一个没有实现Comparable接口的对象转换为Comparable类型,就会抛出这个异常。 为了避免ClassCastException异常的发生,我们需要确保只对兼容的数据类型执行强制类型转换操作。可以使用instanceof运算符检查对象类型,以确定是否可以进行强制类型转换。还可以使用泛型类型来避免在编译时发生类转换异常。最好的方法是尽早发现潜在的问题,并确保在代码编写和测试期间排除它们。 总之,ClassCastException异常是由于尝试将一个对象强制转换为不是其子类的类型或接口类型而导致的。要避免这种异常,我们需要确保只对兼容的数据类型执行强制类型转换,并在编写代码和测试期间尽早发现潜在的问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值