Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/fortran/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 我的ProcessBuilder代码不起作用。从该程序运行craftbukkit_Java_Stream_Processbuilder - Fatal编程技术网

Java 我的ProcessBuilder代码不起作用。从该程序运行craftbukkit

Java 我的ProcessBuilder代码不起作用。从该程序运行craftbukkit,java,stream,processbuilder,Java,Stream,Processbuilder,我试图创建一个程序来运行craftbukkit.jar并处理输入/输出流,但它不起作用 这是我的代码,我做错了什么 package info.nordbyen.bukkitwrapper; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; imp

我试图创建一个程序来运行craftbukkit.jar并处理输入/输出流,但它不起作用

这是我的代码,我做错了什么

package info.nordbyen.bukkitwrapper;

import java.io.BufferedReader; 
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;

public class BukkitWrapper 
{
private final static String PATH_TO_JAVA_PROGRAM = "C:\\Program Files\\Java\\jre7\\bin";
private final static String NAME_OF_JAVA_PROGRAM = "java.exe";

private final static String PATH_TO_CRAFTBUKKIT_FILE = "C:\\l0lkj\\bukkit\\1.7.10_wrapper_tester";
private final static String NAME_OF_CRAFTBUKKIT_FILE = "craftbukkit-1.7.10-R0.1-20140808.005431-8";

private static Process process = null;
private static BufferedReader in = null;
private static OutputStream os = null;

private static Scanner scanner;

public static void main( String[] args )
{
    scanner = new Scanner( System.in );

    System.out.println( "Starter..." );
    ProcessBuilder processBuilder = new ProcessBuilder( PATH_TO_JAVA_PROGRAM + "\\" + NAME_OF_JAVA_PROGRAM, "-jar", PATH_TO_CRAFTBUKKIT_FILE + "\\" + NAME_OF_CRAFTBUKKIT_FILE ); //,"--nojline"
    try 
    {
        process = processBuilder.start();
    } 
    catch ( IOException e ) 
    {
        System.out.println( "ERROR!" );
        System.out.println( e );
        System.exit( -1 );
    }
    if( process == null )
    {
        System.out.println( "ERROR!" );
        System.out.println( "process is null" );
        System.exit( -1 );
    }
    InputStream is = process.getInputStream();
    os = process.getOutputStream();
    if( is == null )
    {
        System.out.println( "ERROR!" );
        System.out.println( "is is null" );
        System.exit( -1 );
    }
    if( os == null )
    {
        System.out.println( "ERROR!" );
        System.out.println( "os is null" );
        System.exit( -1 );
    }
    in = new BufferedReader( new InputStreamReader( is ) );

    inputHandler();
    outputHandler();
}

private static void inputHandler()
{
    Thread thread = new Thread()
    {
        public void run()
        {
            while( true )
            {
                String line = scanner.nextLine();
                try 
                {
                    os.write( line.getBytes() );
                }
                catch ( IOException e ) 
                {
                    System.out.println( "ERROR!" );
                    System.out.println( e );
                    System.exit( -1 );
                }
            }
        }
    };
    thread.start();
}

private static void outputHandler()
{
    while( true )
    {
        String line = null;
        try 
        {
            line = in.readLine();
        } 
        catch ( IOException e ) 
        {
            System.out.println( "ERROR!" );
            System.out.println( e );
        }
        System.out.println( currentTime() + line );
    }
}

private static String currentTime()
{
    SimpleDateFormat sdf = new SimpleDateFormat( "[yyyy-mm-dd hh:mm:ss] -> " );
    Date now = new Date();
    String date = sdf.format( now );
    return date;
}
}
我没有收到任何错误,但输入一直返回null。这是控制台:

[2014-04-12 04:04:06] -> null
[2014-04-12 04:04:06] -> null
[2014-04-12 04:04:06] -> null
[2014-04-12 04:04:06] -> null
[2014-04-12 04:04:06] -> null
Etc. Etc.
谢谢你的帮助:)

编辑: 对于有相同问题的人,只需添加

processBuilder.redirectErrorStream(true);
processBuilder.redirectOutput();
processBuilder.redirectInput();
正如卢克·伍德沃德(Luke Woodward)在回答中所说,在创建流程之前

对于
null
问题,我刚刚添加了一个简单的
if
语句:

if( line.length() >= 1 )
{
    System.out.println( Div.currentTime() + line );
}
我仍然有一个问题,写文字的过程。有人知道如何解决这个问题吗

编辑2:
现在一切正常:)

我有几点建议:

(1) 调用processBuilder.redirectErrorStream(true),在创建进程之前,将进程的标准错误重定向到其标准输出。进程可能正在将消息写入其标准错误,但如果您只读取标准输出,则可能看不到它们

(2) 当BufferedReader的
readLine()
返回
null
时,底层流已到达文件末尾。尝试阅读没有任何意义,因为您只会得到进一步的
null
s。当调用
readLine()
返回
null
时,您应该
中断
循环进入
outputhHandler


我不能保证这些建议会完全解决您的问题,但它们至少可以帮助您找出程序无法运行的原因。

我添加了:
processBuilder.redirectErrorStream(true)
processBuilder.redirectOutput()
processBuilder.redirectInput()现在我从服务器上获取行。非常感谢你!您提到的“向进程写入文本的问题”是什么?我试图在控制台中写入一些文本,但服务器(进程)没有响应。我把它改成了印刷机,所以现在可以用了。我忘记更新问题了好的,很高兴听到你把问题解决了。