jline 在Eclipse下的运行有关问题
最近用到karaf,而karaf的控制台使用了jline处理控制台输入。
在Eclipse下运行时,控制台无法接受输入,输入命令、回车,系统没反应。
原因是在通过JNI调用本地WindowsAPI时,本地的private static final native int ReadConsoleInputW()方法返回了非预期的值。导致控制台读取部分实际上处于死循环状态。
解决方法:设置系统属性jline.WindowsTerminal.directConsole为false。
(绕过本地库Windows API调用,直接使用Java IO流读取输入)
主要参考了:http://whitesock.iteye.com/blog/692816
打开jline的日志:设置系统属性jline.internal.Log.debug为true
另外,要调试jline的话,几个依赖库:
<dependency>
<groupId>org.fusesource.hawtjni</groupId>
<artifactId>hawtjni-runtime</artifactId>
<version>1.11</version>
</dependency>
<dependency>
<groupId>org.fusesource.jansi</groupId>
<artifactId>jansi-native</artifactId>
<version>1.5</version>
</dependency>
<dependency>
<groupId>jline</groupId>
<artifactId>jline</artifactId>
<version>2.13</version>
</dependency>
调试代码:
public static void main(String[] args) throws Exception {
System.setProperty("jline.internal.Log.debug", "true");
//System.setProperty("jline.WindowsTerminal.directConsole", "false");
ConsoleReader console = new ConsoleReader();
String line = console.readLine();
System.out.println("----" + line);
}