gpt4 book ai didi

java - 从网络读取数据

转载 作者:行者123 更新时间:2023-11-30 03:30:07 25 4
gpt4 key购买 nike

我需要读取 http://cs.armstrong.edu/liang/data/Lincoln.txt 上的字数。我编写了程序,NetBeans 没有给我任何错误。然而,该程序似乎是无限的。它不会停止尝试执行,并且最终没有给出答案(甚至没有计算出答案,我不确定)。下面是代码。

import java.net.*;
import java.util.Scanner;
import java.io.IOException;
public class readDataFromWeb {
public static void main(String[] args) {
try {
URL url = new URL("http://cs.armstrong.edu/liang/data/Lincoln.txt");
int wordCount = 0;
Scanner input = new Scanner(url.openStream());
while(input.hasNext()) {
wordCount++;
}
System.out.println(url + " has " + wordCount + " words.");
}
catch (MalformedURLException ex) {
System.out.println("Invalid URL");
}
catch (IOException ex) {
System.out.println("I/O Errors: No such file");
}

}
}

我的印象是,首先声明了 URL 类型的变量 url 并将其设置为 http://cs.armstrong.edu/liang/data/Lincoln.txt 。这是我出错的地方吗?我是否输入了错误的内容?如果需要的话我可以提供更多信息。也欢迎任何风格或概念见解;我正在尝试学习。谢谢!

最佳答案

您实际上从未从扫描仪中读取过任何文字。 hasNext 返回 true,因为有一个单词您可以读...但您从未真正读过它,因此它一直准备好供您阅读,因此 hasNext 不断返回 true。

只需在循环内调用input.next()即可。

关于java - 从网络读取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29247387/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com