如何解决为什么它会创建 indexoutofbounds 错误以及如何修复它?
我只是想写一个小程序,列出 10 到 1000 之间的所有质数,但它不断报告错误(索引 0 超出范围,长度为 0 在 PrimeFinder.main),我不确定我哪里做错了。
class PrimeFinder {
static boolean isPrime(int n) {
for (int x=2; x<=(int)Math.sqrt(n); x++) {
if (n%x == 0) {
return false;
}
}
return true;
}
public static void main(String[] args) {
if (args.length > 0) {
System.out.println("usage: java PrimeFinder <max-range>");
return;
}
int maxRange = Integer.parseInt(args[0]);
for (int i=2; i > 10 && i < 1000; i++) {
if (isPrime(i)) {
System.out.println(i);
}
}
}
}
解决方法
根据,
if (args.length > 0) {
System.out.println("usage: java PrimeFinder <max-range>");
return;
}
您不希望任何用户输入程序。如果有任何用户输入,那么您的程序将退出并在控制台中打印日志。如果没有用户输入,则流程将继续,然后使用该行,
int maxRange = Integer.parseInt(args[0]);
您正在评估实际上是空的 args[]
。所以它会抛出 IndexOutOfBound
错误
如果您不需要对用户输入执行任何验证(至少您没有对代码中的 maxRange
进行任何有用的操作),只需从代码中删除以下几行,
/*
if (args.length > 0) {
System.out.println("usage: java PrimeFinder <max-range>");
return;
}
int maxRange = Integer.parseInt(args[0]);
*/
或者纠正那里的逻辑。
例如:
if (args.length == 0) {
System.out.println("usage: java PrimeFinder <max-range>");
return;
}
并且 main 中的 for 循环应该更正如下,
for (int i=11; i > 10 && i < 1000; i++) {
if (isPrime(i)) {
System.out.println(i);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。