This question already has answers here:
How to avoid ArrayIndexOutOfBoundsException or IndexOutOfBoundsException? [duplicate]
(2个答案)
3年前关闭。
我正在使用Duke进行记录链接,并且在基本测试中,我从CSVReader获得了此异常java.lang.ArrayIndexOutOfBoundsException:1000。
这是我的Java类:
这是配置文件:
有人知道问题出在哪里吗?
堆栈跟踪:
}
根据您的堆栈跟踪,此块中正在发生错误:
问题是CSVReader
这些是您的选择恕我直言:
选项1:获取源代码(派生项目),增加
选项2:检查GitHub项目页面,以查看是否存在与此问题相关的任何未解决的问题(或仅解决一个问题),并确定文件中是否存在任何格式错误的信息,可能导致该
我建议您选择方案2,除非您急忙。
祝好运!
(2个答案)
3年前关闭。
我正在使用Duke进行记录链接,并且在基本测试中,我从CSVReader获得了此异常java.lang.ArrayIndexOutOfBoundsException:1000。
这是我的Java类:
Configuration config = ConfigLoader.load("resources/dukeConfiguration.xml");
Processor proc = new Processor(config);
proc.addMatchListener(new PrintMatchListener(true, true, true, false,
config.getProperties(),
true));
proc.link();
proc.close();
这是配置文件:
<duke>
<schema>
<threshold>0.7</threshold>
<property type="id">
<name>ID</name>
</property>
<property>
<name>TITLE</name>
<comparator>no.priv.garshol.duke.comparators.Levenshtein</comparator>
<low>0.09</low>
<high>0.93</high>
</property>
<property>
<name>ARTIST</name>
<comparator>no.priv.garshol.duke.comparators.Levenshtein</comparator>
<low>0.04</low>
<high>0.73</high>
</property>
</schema>
<group>
<jdbc>
<param name="driver-class" value="com.mysql.jdbc.Driver" />
<param name="connection-string" value="jdbc:mysql://localhost:3306/digitalmusic" />
<param name="user-name" value="root" />
<param name="password" value="root" />
<param name="query" value="select * from inventory" />
<column name="idsong" property="ID" />
<column name="title" property="TITLE" />
<column name="artist" property="ARTIST" />
</jdbc>
</group>
<group>
<csv>
<param name="input-file" value="/home/mongo.csv" />
<param name="header-line" value="false" />
<column name="1" property="ID" />
<column name="2" property="TITLE" />
<column name="3" property="ARTIST" />
</csv>
</group>
</duke>
有人知道问题出在哪里吗?
堆栈跟踪:
Records: 0
Records: 40000
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 1000
at no.priv.garshol.duke.utils.CSVReader.next(CSVReader.java:70)
at no.priv.garshol.duke.datasources.CSVDataSource$CSVRecordIterator.findNextRecord(CSVDataSource.java:170)
at no.priv.garshol.duke.datasources.CSVDataSource$CSVRecordIterator.next(CSVDataSource.java:198)
at no.priv.garshol.duke.datasources.CSVDataSource$CSVRecordIterator.next(CSVDataSource.java:111)
at no.priv.garshol.duke.Processor.linkRecords(Processor.java:362)
at no.priv.garshol.duke.Processor.link(Processor.java:319)
at no.priv.garshol.duke.Processor.link(Processor.java:298)
at no.priv.garshol.duke.Processor.link(Processor.java:285)
at duke.DukeCollecting.main(DukeCollecting.java:20)
最佳答案
好,这是您的问题。
根据latest source posted @ GitHub,当您实例化新的CSVReader
时,会发生这种情况:
public CSVReader(Reader in, int buflen, String file) throws IOException {
this.buf = new char[buflen];
this.pos = 0;
this.len = in.read(buf, 0, buf.length);
this.tmp = new String[1000];
this.in = in;
this.separator = ','; // default
this.file = file;
}
根据您的堆栈跟踪,此块中正在发生错误:
if (escaped_quote)
tmp[colno++] = unescape(new String(buf, prev + 1, pos - prev - 1));
else
tmp[colno++] = new String(buf, prev + 1, pos - prev - 1);
问题是CSVReader
colno
大于先前分配的数组1000
的容量,因此生成了java.lang.ArrayIndexOutOfBoundsException
这些是您的选择恕我直言:
选项1:获取源代码(派生项目),增加
tmp
缓冲区,直到程序运行无错误并重新编译;要么选项2:检查GitHub项目页面,以查看是否存在与此问题相关的任何未解决的问题(或仅解决一个问题),并确定文件中是否存在任何格式错误的信息,可能导致该
array overflow
。我建议您选择方案2,除非您急忙。
祝好运!
关于java - 公爵CSVReader ArrayIndexOutOfBoundsException ,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/34667175/
10-09 00:39