- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的 Process
的 InputStream
应该在用户想要或不想看到它时附加和分离。附加工作正常,但分离失败。中断 readLine()
方法的默认答案始终是关闭流,但在这种情况下我不能这样做,否则 Process
将完成或至少无法用于 future 的附件。这是流的读取方式:
BufferedReader reader = new BufferedReader(new InputStreamReader(getProcess().getInputStream()));
String line;
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
为了分离我尝试了一些东西:
SequenceInputStream
实现另一个流来发送 null/abortion 值,失败:当一个 InputStream
正在等待输入时,另一个甚至没有被调用使用反射解锁任何流中的 read()
方法,失败:不确定原因,但没有成功。 我们应该继续尝试吗?这是源代码:
try {
Field modifiers = Field.class.getDeclaredField("modifiers");
modifiers.setAccessible(true);
Field fdecoder = stream.getClass().getDeclaredField("sd");
fdecoder.setAccessible(true);
modifiers.setInt(fdecoder, 1);
StreamDecoder decoder = (StreamDecoder) fdecoder.get(stream);
Field flock = decoder.getClass().getSuperclass().getDeclaredField("lock");
flock.setAccessible(true);
modifiers.setInt(flock, 1);
Object lock = (Object) flock.get(decoder);
synchronized (lock) {
lock.notifyAll();
}
} catch (NoSuchFieldException | IllegalAccessException e) {
Wrapper.handleException(Thread.currentThread(), e);
}
不确定我该如何解决这个问题。你能帮我在不关闭流的情况下中断 readLine()
方法吗,既简单又高效?谢谢。
编辑:“性能”是什么意思?我的应用程序没有多少用户,但是有很多进程。 @EJP 的回答并没有错——但在我的应用程序中表现不佳。我不能为数百个进程拥有数百个线程,但我可以拥有与用户观看一样多的进程。这就是我尝试优雅地中断该过程的原因。更少的线程,更少的运行/阻塞线程。这是描述的应用程序 ( https://imgur.com/VUcYUfi.png )向用户发送信息的线程与读取输入的线程相同。
最佳答案
我没想到它会起作用,但 future 实际上是可以取消的(但为什么呢?)。在@Tarun Lalwani 提到 TimeLimiter 之后在 Google 的 Guava 库中,我检查了代码,在我的示例中尝试了它(成功了!)并稍微重写了它 - 让它不是基于时间的,而是基于方法调用的?!
这是我从研究中得到的:BufferedReader
的包装器:
public class CancelableReader extends BufferedReader {
private final ExecutorService executor;
private Future future;
public CancelableReader(Reader in) {
super(in);
executor = Executors.newSingleThreadExecutor();
}
@Override
public String readLine() {
future = executor.submit(super::readLine);
try {
return (String) future.get();
} catch (InterruptedException | ExecutionException e) {
e.printStackTrace();
} catch (CancellationException e) {
return null;
}
return null;
}
public void cancelRead() {
future.cancel(true);
}
}
这class
允许您使用 BufferedReader#readLine()
当你需要它并在你想继续/中断时取消它 Thread
它正在运行。这是它的一些示例代码:
public static void main(String[] args) {
System.out.println("START");
CancelableReader reader = new CancelableReader(new InputStreamReader(System.in));
String line;
new Thread(() -> {
try {
Thread.sleep(10000);
reader.cancelRead();
} catch (InterruptedException e) {
e.printStackTrace();
}
}).start();
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
System.out.println("END");
}
它的输出:
START
> Hello World!
Hello World!
> What's up?
What's up?
END //Exactly after 5 seconds, when the cancel was called
> Hey, you still there?
//No output as expected
我想说的最后一件事是为什么不关闭 InputStream 或为每个进程创建一个线程?在这种情况下 InputStream
是 Process
的流,这意味着我们无法关闭它。一种方法是解锁 readLine()
并返回 null 以完成 while
-循环,但这是用 Reflection
制作的,这不像我们现在的解决方案那么漂亮,而且由于任何原因都不起作用。该应用程序使用许多进程但用户数量有限 - 这就是我们决定每个用户而不是每个进程的线程数量的原因。
我希望你们以后能找到这个线程,它对你有帮助。如果您留下赞成票,那就太棒了,这样我就可以取回我的赏金代表。也不要忘记给评论点赞!他们帮了我很多,让我找到了正确的解决方案: Interrupt BufferedReader#readLine() without closing InputStream
关于java - 在不关闭 InputStream 的情况下中断 BufferedReader#readLine(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49652999/
我可以做这个科目吗?我的意思是: BufferedReader reader1 = new BufferedReader(new FileReader(new File("file"))); Bu
这个问题已经有答案了: Unhandled Exception Type IOException [duplicate] (4 个回答) Java: import statement vs fully
PrintWriter out = new PrintWriter(DoDSocket.getOutputStream(), true); BufferedReader in = ne
我是java新手。我想从 java 启动的进程中读取标准输出。我在谷歌搜索中得到了以下代码: Runtime rt = Runtime.getRuntime(); Process pr
这个问题已经有答案了: Stream closed and not reopened - Java (2 个回答) Closing Reader/Stream in Java [duplicate]
我有一个片段如下: Process proc = Runtime.getRuntime().exec(command); BufferedReader br = new BufferedReader(
1. 概述 在这个例子中,我们将使用一个BufferedReader类来读取一个名为 "sample.txt "的文件。 BufferedReader类是用来从基于字符的
我正在 youtube 上查看有关 BufferedReader 的教程 https://www.youtube.com/watch?v=yofFVbARIRU 我完全按照他的方式编写代码,但我无法让
我正在尝试编写一个方法来获取一个多行制表符分隔的文件,并将该文件的内容作为字符串数组的数组列表返回(每一行都是一个字符串[],每个这样的字符串[]都是一个元素一个数组列表)。我的问题是,我无法判断输出
我需要从 Java InputStream 中读取以零结尾的字符串。 有没有类似BufferedReader.readLine()的读取零结尾字符串的方法? 最佳答案 package com; imp
String str = ""; try { BufferedReader br = new BufferedReader(new FileRe
我用下面的样式用BufferedReader读取文件 try (BufferedReader br = new BufferedReader(new FileReader("my_file"))) {
我正在编写一些使用clojure.async的函数,以从读取/写入套接字抽象出来。我的目的是可以将值放入 channel 中以进行写入,并从要读取的 channel 中弹出。这样,用户无需担心Read
我正在尝试使用缓冲读取器读取文件,但有时它会跳过一行中的第一个字符。这是我正在阅读的文件: http://files.moonmana.com/forums/Rectangle.h 这是我得到的结果:
我是 Java 新手,我正在尝试使用此类返回 "test.csv" 的内容。这只在我使用本地文件的路径时才有效。 public class CSVtoArray2 { public stati
我正在使用 BufferedReader.readLine() 逐行读取文本文件,但突然它不读取整行,而是只读取仅第一个字符串 示例:如果文本文件中的第一行是: [98.0,20.0,-65.0]
读完整个字符串后,读者会停留在 while 中,甚至不会抛出异常。我正在通过curl 向服务器发送请求。 我尝试更改 curl 的内容类型,更改字符串的内容,并使用另一种方式读取输入,例如扫描仪,但总
我正在使用 BufferedReader 从 ma url 获取数据。 URL url = new URL("http://"); BufferedReader in = new Buffered
我有一个缓冲阅读器,由于某种原因,它不会从我从客户端发送的打印流中读取文本。这是每次 line = in.readline 时失败的点 我也检查过并且服务器已连接。 这是错误 java.net.Soc
第一次这个循环迭代效果很好,但在我按字符“y”以重复之后,下次显示时,它不会让我输入另一个名称。我不知道是什么原因造成的,但是当你需要清除输入缓冲区时,它让我想起了 C。 任何帮助我们都将不胜感激。
我是一名优秀的程序员,十分优秀!