java – 为什么org.apache.xerces.parsers.SAXParser不会跳过utf8编码的xml中的BOM?

我有一个带utf8编码的xml.
文件包含BOM作为文件的开头.
所以在解析过程中我遇到了org.xml.sax.SAXParseException:prolog中不允许使用内容.
我无法从文件删除这3个字节.
我无法将文件加载到内存中并在此处删除它们(文件很大).
因此,出于性能原因,我正在使用SAX解析器,如果它们在“”标记之前存在,则只想跳过这3个字节.
我应该为此继承InputStreamReader吗?

我是java的新手 – 请告诉我正确的方法.

解决方法

这已经出现了,当我遇到它时,我在Stack Overflow上发现了 the answer.链接的答案使用pushbackinputstream来测试BOM.

相关文章

Java中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...