java执行Logcat命令时如何停止线程运行
来源:互联网 发布:淘宝代销怎么编辑宝贝 编辑:程序博客网 时间:2024/05/22 16:20
本人在使用UiAutomator的时候,想多写一个自动收集手机log的方法,使用runtime类执行了adb logcat的方法,但是一直找不到好的方法结束这个线程,网上说有kill pid的,但是这个操作起来略微麻烦了。自己也想了一个destroy线程的方法,一直不好用。提示错误信息如下:
Exception in thread "main" java.lang.NoSuchMethodErrorat 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;@Overridepublic 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();// 此处有依赖关系,先关闭errorReadererrorInput.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();// 此处有依赖关系,先关闭errorReadererrorInput.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
阅读全文
0 0
- java执行Logcat命令时如何停止线程运行
- 如何停止JAVA线程
- 如何停止JAVA线程
- 如何停止JAVA线程
- 如何停止JAVA线程
- 如何停止java线程
- 如何停止JAVA线程
- Java如何停止线程
- 如何停止java线程
- Java如何停止线程
- 如何停止一个正在运行的java线程
- 如何停止一个正在运行的java线程?
- Mac 终端 停止android logcat命令的输出.退出logcat的执行。
- 如何正确停止线程(JAVA)
- 如何停止一个Java线程
- java中如何停止线程
- Java中停止线程执行的方法
- Java中停止线程执行的方法
- Python+React+Websocket+Redis实现的实时多人聊天
- WUSTOJ 1643 WEB浏览器(栈的使用)
- 铜牌汇总1
- Qt基础
- 机器学习相关英文术语
- java执行Logcat命令时如何停止线程运行
- 8.IP地址相关
- vmware新建opensuse42.3系统图文教程
- Nginx http 500错误分析及解决方法
- git config
- 程序员跨越式成长指南
- 队列
- 你嘴上说的普通人,是几个意思
- mockplus做原型