为什么这个Java代码没有用#跳过?

前端之家收集整理的这篇文章主要介绍了为什么这个Java代码没有用#跳过?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是一个新手,但我试图允许 Java脚本读取的外部.txt文件能够在文件的开头有一些注释,以便其他人可以轻松编辑它并添加更多内容.
但是如果文件包含#(为一行注释指定的符号),它只返回错误,即文件中存在“格式错误”(IOException – 所以它超过了第一个“IF”… )
有人可以帮忙吗?

以下是代码部分,用于处理在脚本中先前调用的.txt文件中的注释行:

while ((line = br.readLine()) != null) {
    line = line.trim();
    if (line.length() < 1 || line.charAt(0) == '#') { // ignore comments
     continue;
    }
    final String[] parts = line.split("=");
    if (parts.length != 2) {
     throw new IOException("Format error in file "
       + JLanguageTool.getDataBroker().getFromRulesDirAsUrl(getFileName())
       + ",line: " + line);
    }@H_404_7@ 
 

input.txt文件在第一行中断它:

06001

这是实际的错误

06002

file:/D:/Documents……./coherency.txt,
line: #This is a Test
at rules.km.KhmerSimpleReplaceRule.loadWords(KhmerSimpleReplaceRule.java:165)
at rules.km.KhmerSimpleReplaceRule.loadWords(KhmerSimpleReplaceRule.java:82)
…33 more

并且堆栈跟踪错误

Caused by: java.io.IOException: Format
error in file
[Ljava.lang.StackTraceElement;@1cb2795
at
km.KhmerSimpleReplaceRule.loadWords(KhmereSimpleReplaceRule.java:
169)

解决方法

在您的第一个可见角色前面可能有一个UTF-8字节顺序标记.大多数编辑器都不会显示这些字符,因为它只预测内容的编码,Java不会删除UTF-8字节顺序标记(与UTF-16和32不同).如果确实存在UTF-8 BOM,您必须自己删除这三个字节.

有关更多详细信息,请参阅Java-Bug 6378911.

原文链接:https://www.f2er.com/java/127152.html

猜你在找的Java相关文章