[英]python how to keep one thread executing till other threading finished
我希望在操作应用程序(例如,进行猴子测试)时记录应用程序(例如,com.clov4r.android.nil)的CPU使用率,并在完成应用程序(例如,完成猴子测试)时完成记录。 如何用python实现呢?
一些代码:
packagename = 'com.clov4r.android.nil'
cmd1 = 'adb shell top -d 5 | grep com.clov4r.android.nil'
cmd2 = 'adb shell monkey -v -p com.clov4r.android.nil --throttle 500 --ignore-crashes --ignore-timeouts --ignore-security-exceptions --monitor-native-crashes -s 2345 100'
t1 = threading.Thread(target=subprocess.call(cmd1, stdout=open(r'123.txt', 'w')))
t2 = threading.Thread(target=subprocess.call(cmd2))
您可以使用Thread.join() :
import threading, time
def worker():
time.sleep(5)
t = threading.Thread(target=worker)
t.start()
t.join()
print('finished')
事件是在线程之间进行通信的好方法( http://docs.python.org/2/library/threading.html#event-objects )。 但是,您将遇到的另一个问题是top命令将永远运行。 我会做这样的事情:
def run_top(event, top_cmd):
s = subprocess.Popen(top_cmd, stdout=open('123.txt', 'w'))
event.wait() # Wait until event is set, then kill subprocess
s.kill()
def run_monkey(event, monkey_cmd):
subprocess.call(monkey_cmd)
event.set() # Once we're finished set the event to tell the other thread to exit
event = threading.Event()
threading.Thread(target=run_top, args=(event, your_top_command)).start()
threading.Thread(target=run_monkey, args=(event, your_monkey_command)).start()
也可能有一种杀死线程的方法,但这很丑陋,这种方法受控制得多。
我还要说run_monkey()不需要在线程中运行,但是不确定您拥有哪些其他代码可能需要它。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.