使用输入流阅读器读取时缺少行

我有一个示例EXE打印在输出下面。

EXE输出:

1
2
3
4
5
Failed

在java中的等效代码:

for (int i = 1; i <= 5; i++){
     System.out.println(i);
}
System.out.println("Failed");

当试图使用java代码启动EXE并读取输出时,一些数据会丢失。

找到启动资产的Java。

Java代码:

String[] commands = new String[] {"sample.exe" };
p = Runtime.getRuntime().exec(commands);
InputStream is = p.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr);
while  ((line = br.readLine()) != null) {
    line = br.readLine()
    System.out.println(line);
    if(line.toLowerCase().contains("failed")){
           #Apply business Rule.
    }
}

输出:

1
3
5

从上面的输出中可以明显看出我们缺少像2,3,5,failed这样的数据2,3,5,failed

我认为在我们阅读使用InputStreamReader之前资产已经完成。 有没有什么办法可以让资产等到我们读完使用InputStreamReader并开始下一组指令,或者是否还有其他更好的方法来实现这一点。

EDIT1:

在我的原始代码中,我也在平行读取错误流,请查找代码。

ErrorStreamReader:

public void run () {
    try {

        InputStreamReader isr = new InputStreamReader (is);
        BufferedReader br = new BufferedReader (isr); 
        while (true) {
                String s = br.readLine ();
                System.out.println(s+"error Stream");
                if (s == null) break;
            }

    is.close ();    
    } catch (Exception ex) {
        System.out.println ("Problem reading stream " + name + "... :" + ex);
        ex.printStackTrace ();
    }
}

EXE执行器java代码:

String[] commands = new String[] {"sample.exe" };
p = Runtime.getRuntime().exec(commands);
Thread errorStream = new Thread(new ReadStream("stderr", 
    p.getErrorStream ()) # Reads error Stream In parallel
InputStream is = p.getInputStream();
InputStreamReader isr = new InputStreamReader(is);
BufferedReader br = new BufferedReader(isr);
while  ((line = br.readLine()) != null) {
    line = br.readLine()
    System.out.println(line);
    if(line.toLowerCase().contains("failed")){
           #Apply business Rule.
    }
}

它看起来像输入流阅读器一次跳过一行读取。

EDIT2:

由于我认为InputStreamReader甚至缺少数字行,所以我在EXE(一个python脚本)中进行了更改,以便从16打印,然后失败。

修改后的EXE输出:

1
2
3
4
5
6
Failed

现在InputStreamReader的输出是

Java输出:

1
3
5
Failed

正如我以为我错过了奇数行。 有人能让我知道原因吗?


注意:

问题是由于读取inputStream Twice抱歉造成的不便。 我非常抱歉。


问题是由于读取了两次inputStream

while  ((line = br.readLine()) != null) {
    line = br.readLine() # input stream read here twice
    System.out.println(line);
    if(line.toLowerCase().contains("failed")){
           #Apply business Rule.
    }
}

因此,这个问题。 要解决它,我只能读一次inputStream。

while  ((line = br.readLine()) != null) {
    System.out.println(line);
    if(line.toLowerCase().contains("failed")){
           #Apply business Rule.
    }
}
链接地址: http://www.djcxy.com/p/93991.html

上一篇: Missing line when reading using input stream reader

下一篇: long COMMIT duration, high I/O wait in postgres 9.1