python开发之thread线程基础实例入门
本文实例讲述了python开发之thread线程基础。分享给大家供大家参考,具体如下:
说到线程,我们要知道啥是串行,啥是并行程序
举个例子:
串行程序,就是一个一个的执行程序
#pythonthreading importtime ''' 每一秒中,输出:thisisademo! ''' defserial(): '''串行输出''' time.sleep(1) print('thisisademo!') defmain(): foriinrange(5): serial() if__name__=='__main__': main()
运行结果如下:
>>> thisisademo! thisisademo! thisisademo! thisisademo! thisisademo! >>>
并行程序,就是很多个程序在同一时间(宏观)一起执行
#pythonthreading importthreading importtime ''' 并行执行,输出:Good!Good!Good!Good!Good! ''' defparallel(): '''并行输出''' time.sleep(1) print('Good!') defmain(): foriinrange(5): t=threading.Thread(target=parallel) t.start() if__name__=='__main__': main()
当然我们通过执行程序,可以知道,并行程序要比串行程序执行的要快....
我们也可以获取到当前的线程及个数:
#pythonthreading importthreading importtime ''' 并行执行,输出: [<Thread(Thread-2,started3480)>,<Thread(Thread-1,started660)>, <Thread(SockThread,starteddaemon2920)>,<Thread(Thread-3,started916)>, <Thread(Thread-4,started3476)>,<_MainThread(MainThread,started3964)>, <Thread(Thread-5,started2060)>] 存在的线程数:7 Good!Good!Good!Good!Good! ''' defparallel(): '''并行输出''' time.sleep(1) print('Good!') defmain(): foriinrange(5): t=threading.Thread(target=parallel) t.start() if__name__=='__main__': main() print(threading.enumerate()) print('存在的线程数:%d'%threading.active_count())
运行结果如下:
>>> [<Thread(SockThread,starteddaemon15424)>,<Thread(Thread-3,started15840)>,<Thread(Thread-1,started10884)>,<Thread(Thread-2,started14512)>,<Thread(Thread-4,started13204)>,<_MainThread(MainThread,started12924)>,<Thread(Thread-5,started15476)>] 存在的线程数:7 >>>Good!Good!Good!Good!Good!
希望本文所述对大家Python程序设计有所帮助。