Любой способ запуска команд оболочки на Android программно?

Есть ли способ запустить команды терминала в моем приложении, а затем получить доступ к данным в моем интерфейсе? конкретно top,

5 ответов

Решение

Проверьте Log Collector в качестве примера. Вот соответствующий файл.

Ключ здесь:

ArrayList<String> commandLine = new ArrayList<String>();
commandLine.add("logcat");//$NON-NLS-1$
[...]

Process process = Runtime.getRuntime().exec(commandLine);
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream()));

Ладно, это именно то, что сработало для меня на всякий случай, если кому-то это понадобится в будущем...

Окружите в попытке поймать

try {
    Process process = Runtime.getRuntime().exec("top -n 1 -d 1");
    BufferedReader in = new BufferedReader(new InputStreamReader(process.getInputStream()));
} catch (InterruptedException e) {
    e.printStackTrace();
}

Мы можем выполнять команды следующим образом, я был успешен в этом....! попробуйте вот так, здесь нам нужно указать полный путь к команде. чтобы получить полный путь к команде, введите в терминале ur (android)

*$ который ls

/ Система / бен *

try {

    // Executes the command.

    Process process = Runtime.getRuntime().exec("/system/bin/ls /sdcard");

    // Reads stdout.
    // NOTE: You can write to stdin of the command using
    //       process.getOutputStream().
    BufferedReader reader = new BufferedReader(
            new InputStreamReader(process.getInputStream()));
    int read;
    char[] buffer = new char[4096];
    StringBuffer output = new StringBuffer();
    while ((read = reader.read(buffer)) > 0) {
        output.append(buffer, 0, read);
    }
    reader.close();

    // Waits for the command to finish.
    process.waitFor();

    return output.toString();
} catch (IOException e) {

    throw new RuntimeException(e);

} catch (InterruptedException e) {

    throw new RuntimeException(e);
}

Это также зависит от того, что вы запускаете в терминале... если вы запускаете "cat" для файла, вы также можете сделать это следующим образом.

final private String MEM_FILE = "/proc/meminfo";

public Long readMem() {
    String[] segs;
    FileReader fstream;
    try {
        fstream = new FileReader(MEM_FILE);
    } catch (FileNotFoundException e) {
        Log.e("readMem", "Could not read " + MEM_FILE);
        return false;
    }
    BufferedReader in = new BufferedReader(fstream, 500);
    String line;
    try {
        while ((line = in.readLine()) != null) {
            if (line.indexOf("MemTotal:") > 0) {
                Log.e("MemTotal", line);
                segs = line.trim().split("[ ]+");
                memTotal = Long.parseLong(segs[1]);
            }
            if (line.indexOf("MemFree:") > 0) {
                Log.e("MemFree", line);
                segs = line.trim().split("[ ]+");
                memFree = Long.parseLong(segs[1]);
            }
        }
        updateMem(); //call function to update textviews or whatever
        return true;
    } catch (IOException e) {
        Log.e("readMem", e.toString());
    }
    return false;
}

РЕДАКТИРОВАТЬ: есть отличный пример для вас в проекте android labs под названием netmeter. Существует класс Top.java, который на самом деле делает именно то, что вы хотите, и он используется в TaskList.java для отображения. http://code.google.com/p/android-labs/source/browse/

Для энтузиастов Kotlin вы можете использовать следующие

      fun executeShell() {
    val command: String = "top -n 1"
    try {
        val process: Process = Runtime.getRuntime().exec(command)
        // Read the lines using BufferedReader
        BufferedReader(InputStreamReader(process.inputStream)).forEachLine {
            // Do something on each line read
            Log.d(this::class.java.canonicalName, "$it")
        }
    } catch (e: InterruptedException) {
        Log.w(this::class.java.canonicalName, "Cannot execute command [$command].", e)
    } catch (e: Exception) {
        Log.e(this::class.java.canonicalName, "Cannot execute command [$command].", e)
    }
}

Вам даже не нужно будет заботиться о закрытии буфера, так как об этом позаботится функция расширения forEachLine .

Другие вопросы по тегам