一:threading VS Thread
众所周知,python是支持多线程的,而且是native的线程,其中threading是对Thread模块做了包装,可以更加方面的被使用,threading模块里面主要对一些线程操作对象化了,创建了Thread的类。
使用线程有两种模式,一种是创建线程要执行的函数,把这个函数传递进Thread对象里,让它来执行,一种是直接从Thread继承,创建一个新的class,把线程执行的代码放到这个新的类里面,用例如下:
①使用Thread来实现多线程
#!/usr/bin/env python #-*- coding:utf-8 -*- import string import threading import time def threadMain(a): global count,mutex #获得线程名 threadname = threading.currentThread().getName() for x in xrange(0,int(a)): #获得锁 mutex.acquire() count += 1 #释放锁 mutex.release() print threadname,x,count time.sleep() def main(num): global count,mutex threads = [] count = 1 #创建一个锁 mutex = threading.Lock() #先创建线程对象 for x in xrange(0,num): threads.append(threading.Thread(target = threadMain,args=(10,))) for t in threads: t.start() for t in threads: t.join() if __name__ == "__main__": num = 4 main(num);
②使用threading来实现多线程
#!/usr/bin/env python #-*- coding:utf-8 -*- import threading import time class Test(threading.Thread): def __init__(self,num): threading.Thread.__init__(self): self._run_num = num def run(self): global count,mutex threadName = threading.currentThread.getName() for x in xrange(0,int(self._run_num)): mutex.acquire() count += 1 mutex.release() print threadName,x,count time.sleep(1) if __name__ == "__main__": global count,mutex threads = [] num = 4 count = 1 mutex.threading.Lock() for x in xrange(o,num): threads.append(Test(10)) #启动线程 for t in threads: t.start() #等待子线程结束 for t in threads: t.join()
二:optparser VS getopt
①使用getopt模块处理Unix模式的命令行选项
getopt模块用于抽出命令行选项和参数,也就是sys.argv,命令行选项使得程序的参数更加灵活,支持短选项模式和长选项模式
例:python scriptname.py –f “hello” –directory-prefix=”/home” –t --format ‘a'‘b'
getopt函数的格式:getopt.getopt([命令行参数列表],‘短选项',[长选项列表])
其中短选项名后面的带冒号(:)表示该选项必须有附加的参数
长选项名后面有等号(=)表示该选项必须有附加的参数
返回options以及args
options是一个参数选项及其value的元组((‘-f','hello'),(‘-t',''),(‘—format',''),(‘—directory-prefix','/home'))
args是除去有用参数外其他的命令行 输入(‘a',‘b')
#!/usr/bin/env python # -*- coding:utf-8 -*- import sys import getopt def Usage(): print "Usage: %s [-a|-0|-c] [--help|--output] args..."%sys.argv[0] if __name__ == "__main__": try: options,args = getopt.getopt(sys.argv[1:],"ao:c",['help',"putput="]): print options print "\n" print args for option,arg in options: if option in ("-h","--help"): Usage() sys.exit(1) elif option in ('-t','--test'): print "for test option" else: print option,arg except getopt.GetoptError: print "Getopt Error" Usage() sys.exit(1)
②optparser模块
#!/usr/bin/env python # -*- coding:utf-8 -*- import optparser def main(): usage = "Usage: %prog [option] arg1,arg2..." parser = OptionParser(usage=usage) parser.add_option("-v","--verbose",action="store_true",dest="verbose",default=True,help="make lots of noise [default]") parser.add_option("-q","--quiet",action="store_false",dest="verbose",help="be vewwy quiet (I'm hunting wabbits)") parser.add_option("-f","--filename",metavar="FILE",help="write output to FILE") parser.add_option("-m","--mode",default="intermediate",help="interaction mode: novice, intermediate,or expert [default: %default]") (options,args) = parser.parse_args() if len(args) != 1: parser.error("incorrect number of arguments") if options.verbose: print "reading %s..." %options.filename if __name__ == "__main__": main()
以上就是threading VS Thread、optparser VS getopt 的相互比较,希望对大家学习模块有所帮助。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]