ProcessBuilder против Runtime.exec ()
Я пытаюсь создать приложение на Java для обработки пакетных SVG-преобразований с помощью функции командной строки Inkscape. Я беру и обновляю код отhttps://sourceforge.net/projects/conversionsvg/, То, как оригинальный разработчик обрабатывал вызов InkscapeRuntime.getRuntime (). Exec (String), Проблема, с которой я сталкиваюсь, заключается в некоторых несоответствиях между использованием methodA и methodB. Я создал простой тестовый проект Java, чтобы продемонстрировать различные выполняемые действия.
CallerTest.java
package conversion;
import java.io.IOException;
public class CallerTest {
static String pathToInkscape = "\"C:\\Program Files\\Inkscape\\inkscape.exe\"";
public static void main(String[] args) {
ProcessBuilderCaller processBuilder = new ProcessBuilderCaller();
RuntimeExecCaller runtimeExec = new RuntimeExecCaller();
// methodA() uses one long command line string
try {
String oneLongString_ProcessBuilder = pathToInkscape + " -f \"C:\\test.svg\" -D -w 100 -h 100 -e \"C:\\ProcessBuilder-methodB.png\"";
String oneLongString_RuntimeExec = pathToInkscape + " -f \"C:\\test.svg\" -D -w 100 -h 100 -e \"C:\\RuntimeExec-methodA.png\"";
// processBuilder.methodA(oneLongString_ProcessBuilder);
runtimeExec.methodA(oneLongString_RuntimeExec);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// methodB() uses an array containing the command and the options to pass to the command
try {
String[] commandAndOptions_ProcessBuilder = {pathToInkscape, " -f \"C:/test.svg\" -D -w 100 -h 100 -e \"C:\\ProcessBuilder-methodB.png\""};
String[] commandAndOptions_RuntimeExec = {pathToInkscape, " -f \"C:/test.svg\" -D -w 100 -h 100 -e \"C:\\RuntimeExec-methodB.png\""};
processBuilder.methodB(commandAndOptions_ProcessBuilder);
// runtimeExec.methodB(commandAndOptions_RuntimeExec);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
RuntimeExecCaller.java
package conversion;
import java.io.IOException;
public class RuntimeExecCaller {
Process process;
// use one string
public void methodA(String oneLongString) throws IOException {
process = Runtime.getRuntime().exec(oneLongString);
}
, // use the array
public void methodB(String[] commandAndOptions) throws IOException {
process = Runtime.getRuntime().exec(commandAndOptions);
}
}
ProcessBuilderCaller.java
package conversion;
import java.io.IOException;
public class ProcessBuilderCaller {
Process process;
// use one string
public void methodA(String oneLongString) throws IOException {
process = new ProcessBuilder(oneLongString).start();
}
// use the array
public void methodB(String[] commandAndOptions) throws IOException {
process = new ProcessBuilder(commandAndOptions).start();
}
}
Результат
И то и другоеMethoda (String) звонки работают, но когдаmethodB (String []) называется Inkscape запускается и аргументы передаются неправильно. ПослеmethodB (String []) выполняет я получаю диалог ошибки Inkscape для каждого высказывания
Не удалось загрузить запрошенный файл -f C: /test.svg -D -w 100 -h 100 -e C: \ RuntimeExec-methodB.png
Не удалось загрузить запрошенный файл -f C: /test.svg -D -w 100 -h 100 -e C: \ ProcessBuilder-methodB.png
и когда я нажимаю кнопку Закрыть в диалоговом окне, Inkscape появляется с новым пустым документом. Итак, я думаю, у меня есть несколько вопросов:
В чем разница между Runtime.getRuntime (). Exec (String) и Runtime.getRuntime (). Exec (String [])?
JavaDoc говорит, чтоRuntime.exec (String) звонкиRuntime.exec (команда, ноль) (которыйRuntime.exec (String cmd, String [] envp)) который в свою очередь вызываетRuntime.exec (cmdarray, envp) (которыйRuntime.exec (String [] cmdarray, String [] envp)). Так что еслиRuntime.getRuntime (). Exec (String) звонитRuntime.exec (String []) В любом случае, почему я получаю разные результаты при использовании разных методов?
Что-то происходит за кулисами, когда Java настраивает среду по-разному в зависимости от того, какой метод вызывается?