java执行Logcat命令时如何停止线程运行
2017-11-06 13:18
1131 查看
本人在使用UiAutomator的时候,想多写一个自动收集手机log的方法,使用runtime类执行了adb logcat的方法,但是一直找不到好的方法结束这个线程,网上说有kill pid的,但是这个操作起来略微麻烦了。自己也想了一个destroy线程的方法,一直不好用。提示错误信息如下:
Exception in thread "main" java.lang.NoSuchMethodError at java.lang.Thread.destroy(Thread.java:990) at monkeytest.Monkey.main(Monkey.java:15)后来自己想了一个办法,在去读input流的时候,多加一个参数来写一个stop的方法。下面是logcat的类代码,分享出来,供大家参考。其中一个destroy的方法得直接去结束process线程,如果子线程在运行的时候,直接调用destroy方法,就会报上面的那个错误。这个是自己总结的,如有错误还请指正。
package monkeytest; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import source.Common; public class Logcat extends Thread { private static boolean LogKey = false; @Override public void run() { execCmdAdb("adb logcat -c"); execCmdAdb("adb logcat", "logcat.log", "happyjuzi", true); } /** * 执行adb命令 * * @param cmd * 命令内容 * @param fileName * 输入文件路径 * @param filter * 过滤词汇 * @param key * 是否包含过滤词汇 */ private void execCmdAdb(String cmd, String fileName, String filter, boolean key) { System.out.println(cmd); String OSname = System.getProperty("os.name"); try { Process p = null; if (OSname.contains("Mac")) { p = Runtime.getRuntime().exec(Common.ADB_PATH + cmd); } else { p = Runtime.getRuntime().exec("cmd /c " + cmd); } // 正确输出流 InputStream input = p.getInputStream();// 创建并实例化输入字节流 BufferedReader reader = new BufferedReader(new InputStreamReader(input));// 先通过inputstreamreader进行流转化,在实例化bufferedreader,接收内容 String line = ""; while ((line = reader.readLine()) != null) {// 循环读取 if (LogKey) { p.destroy();//结束线程 reader.close();// 此处reader依赖于input,应先关闭 input.close(); return; } // System.out.println(line);// 输出 if (key) { if (line.contains(filter)) { Common.getInstance().saveToFile(line, fileName, false);// 保存 } } else { if (!line.contains(filter)) { Common.getInstance().saveToFile(line, fileName, false);// 保存 } } } reader.close();// 此处reader依赖于input,应先关闭 input.close(); // 错误输出流 InputStream errorInput = p.getErrorStream();// 创建并实例化输入字节流 BufferedReader errorReader = new BufferedReader(new InputStreamReader(errorInput));// 先通过inputstreamreader进行流转化,在实例化bufferedreader,接收内容 String eline = ""; while ((eline = errorReader.readLine()) != null) {// 循环读取 if (LogKey) { p.destroy(); errorReader.close();// 此处有依赖关系,先关闭errorReader errorInput.close(); return; } if (key) { if (eline.contains(filter)) { Common.getInstance().saveToFile(line, fileName, false);// 保存 } } else { if (!eline.contains(filter)) { Common.getInstance().saveToFile(line, fileName, false);// 保存 } } } errorReader.close();// 此处有依赖关系,先关闭errorReader errorInput.close(); } catch (IOException e) { Common.getInstance().output("执行" + cmd + "失败!"); e.printStackTrace(); } } private void execCmdAdb(String cmd) { System.out.println(cmd); String OSname = System.getProperty("os.name"); try { if (OSname.contains("Mac")) { Runtime.getRuntime().exec(Common.ADB_PATH + cmd); } else { Runtime.getRuntime().exec("cmd /c " + cmd); } } catch (IOException e) { Common.getInstance().output("执行" + cmd + "失败!"); e.printStackTrace(); } } public void stopLoacat() { Logcat.LogKey = true; } }宣传一下自己的QQ群,欢迎有兴趣的加入:tester终点站:群号:340964272
相关文章推荐
- 如何停止一个正在运行的java线程?
- 如何停止一个正在运行的java线程
- 如何停止一个正在运行的java线程
- 在命令提示符下编译、运行java 以及使用jar命令制作可执行的jar包
- java中,如何安全的结束一个正在运行的线程?
- windows下如何用java命令运行jar包?
- 浅析Java执行外部命令的几个要点(2)——如何支持Timeout
- Java如何等待子线程执行结束
- Java如何等待子线程执行结束
- 【Win32多线程】如何初始化一个新线程,停止一个执行中的线程,调整线程优先权?
- 如何停止JAVA线程
- 在java中如何防止从其它线程类运行run方法
- 如何停止java线程
- windows下如何用java命令运行jar包?
- windows下如何用java命令运行jar包?
- 【转载】Java如何中断一个正在运行的线程
- Java如何调用可执行文件和批处理命令
- 如何停止java线程
- 如何停止JAVA线程
- 如何在java中运行dos命令?如何在java中导出注册表信息?