⭐️前言
首先我们笼统来看几个改善Python程序性能
的建议:
使用合适的数据结构
:选择最适合处理问题的数据结构
可以提高程序性能。例如,使用字典
而不是列表
来查找元素
。
避免冗余计算和循环
:重复计算和循环可能会使程序变慢。通过缓存结果或使用生成器避免冗余计算,避免多次循环可以提高性能。
使用内置函数和库
:内置函数和库通常比手写的代码快得多
,因为它们经过优化和测试
。
避免
过多的对象属性访问
:频繁访问对象属性会使代码变慢
,对于经常访问同一属性的代码可以考虑使用局部变量缓存
这些属性。
使用NumPy或Pandas
:NumPy和Pandas是用于数值计算和数据分析
的Python库,它们针对大型数据集进行了优化
,通常比纯Python代码更快
。
使用并行编程
: Python中的并行编程可以显著提高程序的性能
。使用multiprocessing和threading模块
可以将任务分配给多个处理器和内核
。
代码优化
:分析代码并使用适当的算法和数据结构
,减少函数调用
,避免不必要的内存分配
和使用适当的数据类型都可以提高程序的性能。
⭐️代码举例
说得再多不如我们上手试一试!
下面来看一个具体的我们模拟的买票程序。
🌟 买票程序初始代码
# coding=gbk
import threading
from time import *
from datetime import datetime
tickets=[
["2030","beijing","武汉",10,200],
["3300", "beijing", "武汉", 3, 200],
["2010", "beijing", "武汉", 2, 200],
["3020", "beijing", "武汉", 3, 200],
["1022", "beijing", "武汉", 0, 200],
["5020", "beijing", "武汉", 120, 200],
["4010", "beijing", "武汉", 110, 200]
]
def buy_ticket(name,nums,data1,start_station):
i=0;
sleep(1)
for get_record in tickets:
if get_record[0]==data1 and get_record[1]==start_station:
if get_record[3]>=nums:
tickets[i][3]=get_record[3]-nums
return nums
else:
print("没票了")
return -1
i+=1
print("今天没票了%s"%(name))
return -1
if __name__=="__main__":
print("start time",datetime.now())
result=buy_ticket("张三",2,"3300","beijing")
print(result)
result = buy_ticket("里斯", 2, "3300", "beijing")
print(result)
print(datetime.now())
结果:
start time 2023-03-28 19:30:08.243448
2
没票了
-1
2023-03-28 19:30:10.265600
一共用了小两秒,很普通的结果。
⭐️改进
# coding=gbk
import threading
from time import *
from datetime import datetime
tickets=[
["2030","beijing","武汉",10,200],
["3300", "beijing", "武汉", 3, 200],
["2010", "beijing", "武汉", 2, 200],
["3020", "beijing", "武汉", 3, 200],
["1022", "beijing", "武汉", 0, 200],
["5020", "beijing", "武汉", 120, 200],
["4010", "beijing", "武汉", 110, 200]
]
def buy_ticket(name,nums,data1,start_station):
i=0;
sleep(1)
for get_record in tickets:
if get_record[0]==data1 and get_record[1]==start_station:
if get_record[3]>=nums:
tickets[i][3]=get_record[3]-nums
return nums
else:
print("没票了")
return -1
i+=1
print("今天没票了%s"%(name))
return -1
if __name__=="__main__":
print("start time",datetime.now())
t1=threading.Thread(target=buy_ticket,args=("张三",2,"3300","beijing"))
t2=threading.Thread(target=buy_ticket,args=("里斯", 2, "3300", "beijing"))
print(datetime.now())
哇!!!!!!!!!!!!
看结果!
start time 2023-03-28 20:26:04.097750
没票了
2023-03-28 20:26:05.099602
一秒! 这种程序我们叫做程序怪
!
显而易见,我们节省了一半的时间
!
🌟 多学一点:多线程编程,为什么要调用join方法
在Python中,当一个线程完成了它的工作
,它会进入到"完成"状态
。但是,如果其他线程还在运行
,那么主线程或者其他线
程可能不会在这个线程完成之前终止
。为了避免这种情况
,我们可以调用join()方法
。
join()方法的作用是使主线程等待其他线程完成
。当调用join()方法
时,主线程会阻塞
,直到
该线程执行完毕
并退出。同时,如果某个线程发生异常而未能完成工作
,join()方法可以帮助我们抛出并处理该异常
。
总的来说,join()方法保证了所有线程都执行完毕后才会结束程序
,避免了出现未定义的行为。
⭐️最终版-用类方式实现
# coding=gbk
import threading
from time import *
from datetime import datetime
tickets=[
["2030","beijing","武汉",10,200],
["3300", "beijing", "武汉", 3, 200],
["2010", "beijing", "武汉", 2, 200],
["3020", "beijing", "武汉", 3, 200],
["1022", "beijing", "武汉", 0, 200],
["5020", "beijing", "武汉", 120, 200],
["4010", "beijing", "武汉", 110, 200]
]
def buy_ticket(name,nums,data1,start_station):
i=0;
sleep(1)
for get_record in tickets:
if get_record[0]==data1 and get_record[1]==start_station:
if get_record[3]>=nums:
tickets[i][3]=get_record[3]-nums
return nums
else:
print("没票了")
return -1
i+=1
print("今天没票了%s"%(name))
return -1
class MThread(threading.Thread):# 子类继承
def __init__(self,target,args):# 定义构造函数init
threading.Thread.__init__(self)# 继承父类的init
self.target=target
self.args=args
def run(self) -> None:
self.target(*self.args)
if __name__=="__main__":
visitor=[
("张三", 2, "3300", "beijing"),
("里斯", 2, "3300", "beijing")
]
class_do_list=[]
print("start time",datetime.now())
for get_r in visitor:
getone=MThread(target=buy_ticket,args=get_r)# 产生线程实例
class_do_list.append(getone)
for i in range(len(class_do_list)):
class_do_list[i].start()
for i in range(len(class_do_list)):
class_do_list[i].join()
print(datetime.now())
print(tickets)
效果很好!
start time 2023-03-28 21:13:12.683064
没票了
2023-03-28 21:13:13.692903
[['2030', 'beijing', '武汉', 10, 200], ['3300', 'beijing', '武汉', 1, 200], ['2010', 'beijing', '武汉', 2, 200], ['3020', 'beijing', '武汉', 3, 200], ['1022', 'beijing', '武汉', 0, 200], ['5020', 'beijing', '武汉', 120, 200], ['4010', 'beijing', '武汉', 110, 200]]
我们利用了do-list来做事!非常优雅
class_do_list=[]
for get_r in visitor:
getone=MThread(target=buy_ticket,args=get_r)# 产生线程实例
class_do_list.append(getone)
for i in range(len(class_do_list)):
class_do_list[i].start()
for i in range(len(class_do_list)):
class_do_list[i].join()