我有一个Java程序,连接到一个在线资源,读取数据,然后解析一个特定的信息(这是查看某个页面的活跃reddit帐户的数量) 。java循环没有打印输入流数据第一次迭代后
我想自动执行此过程以给定的时间间隔重复它(为了查看它是否工作,我将间隔设置为5秒)。程序然后将这个数字打印到一个文件中,每次都在不同的行上。我知道主循环是迭代的,因为我的output.txt
文件有几行,但它只能在第一次迭代中找到并打印数字。
package redditreader3;
import java.io.*;
import java.net.Socket;
import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class RedditReader3 {
public static void main(String[] args) throws IOException, InterruptedException
{
int i = 1;
String host = args[0]; // www.reddit.com
String resource = args[1]; // /r/toronto/about.json
final int HTTP_PORT = 80;
String command = "GET " + resource + " HTTP/1.1\n" + "Host:" + host
+ "\n\n";
/* This command requests reddit for the source code of the resource in args[1] at its host, args[0] to be printed through HTTP. */
Socket socket = new Socket(host, HTTP_PORT);
InputStream instream = socket.getInputStream();
Scanner in = new Scanner(instream);
OutputStream outstream = socket.getOutputStream();
PrintWriter out = new PrintWriter(outstream);
File file = new File("output.txt");
FileOutputStream F_outstream = new FileOutputStream(file);
PrintStream F_printstream = new PrintStream(F_outstream);
/* Now that the connection has been established and all of the objects
are connected to each other, the command may be sent and the data
transfer may begin. */
String ActiveAccountsData = ("\"accounts_active\": (\\d+)");
String ActiveAccountsDataFOUND;
Pattern ActiveAccountsPattern = Pattern.compile(ActiveAccountsData);
Matcher ActiveAccountsMatcher;
String input;
while(i <= 4)
{
out.print(command);
out.flush();
while(in.hasNextLine())
{
input = in.nextLine();
ActiveAccountsMatcher = ActiveAccountsPattern.matcher(input);
if(ActiveAccountsMatcher.find())
{
ActiveAccountsDataFOUND = ActiveAccountsMatcher.group(1);
F_printstream.println(ActiveAccountsDataFOUND);
break;
}
}
i++;
F_printstream.println();
Thread.sleep(5000);
}
}
}
我想也许in.hasNextLine()
值被卡住的地方和需要更新,但我不能找到将它返回到该网站输入的开头方法。
你必须调试您的程序以更好地定位问题的根源。将不必要的细节暴露给我们是不好的。其次,一旦你调试你的代码,问题就会很明显。 – Val 2013-02-13 16:10:45