繁体   English   中英

python如何保持一个线程执行直到其他线程完成

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM