java執行Logcat命令時如何中止線程運行

本人在使用UiAutomator的時候,想多寫一個自動收集手機log的方法,使用runtime類執行了adb logcat的方法,可是一直找不到好的方法結束這個線程,網上說有kill pid的,可是這個操做起來略微麻煩了。本身也想了一個destroy線程的方法,一直很差用。提示錯誤信息以下:java

Exception in thread "main" java.lang.NoSuchMethodError
	at java.lang.Thread.destroy(Thread.java:990)
	at monkeytest.Monkey.main(Monkey.java:15)

緣由是由於:destroy()方法會摧毀線程,可是runtime使用中新建了一個子線程,因此纔會報錯。 後來本身想了一個辦法,在去讀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;
	}
}

多線程實現:json

package monkeytest;
 
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.text.SimpleDateFormat;
import java.util.Date;
 
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" + getNow() + ".log");
	}
 
	/**
	 * 執行adb命令
	 * 
	 * @param cmd
	 *            命令內容
	 * @param fileName
	 *            輸入文件路徑
	 * @param filter
	 *            過濾詞彙
	 * @param key
	 *            是否包含過濾詞彙
	 */
	private void execCmdAdb(String cmd, String fileName) {
		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 (line.contains("happyjuzi")) {
					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 (eline.contains("happyjuzi")) {
					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();
		}
	}
 
	/**
	 * 中止logcat線程
	 */
	public void stopLoacat() {
		Logcat.LogKey = true;
	}
 
	/**
	 * 獲取當前時間
	 * 
	 * @return 返回當前時間,只有日期和小時和分數沒有年份和秒數
	 */
	private String getNow() {
		Date time = new Date();
		SimpleDateFormat now = new SimpleDateFormat("MMdd-HHmm");
		String c = now.format(time);
		return c;
	}
}
  • 這裏須要注意一點logcat類的使用方法,不能一直讓這個線程運行,否則log文件會很大,每次讀寫log文件的時候會愈來愈消耗資源。能夠本身在logcat類裏面作一個循環也能夠在使用logcat線程的時候作循環,我用的後者,由於個人其餘線程也是寫在測試腳本的循環當中。

往期文章精選

  1. java一行代碼打印心形
  2. Linux性能監控軟件netdata中文漢化版
  3. 接口測試代碼覆蓋率(jacoco)方案分享
  4. 性能測試框架
  5. 如何在Linux命令行界面愉快進行性能測試
  6. 圖解HTTP腦圖
  7. 寫給全部人的編程思惟
  8. 測試之JVM命令腦圖
  9. 將json數據格式化輸出到控制檯

公衆號地圖 ☢️ 一塊兒來~FunTester

相關文章
相關標籤/搜索