【python实操】如何改善你的程序,让你的程序更快执行?

news/2024/10/28 19:20:47/
  • 作者:20岁爱吃必胜客(坤制作人),近十年开发经验, 跨域学习者,目前于海外某世界知名高校就读计算机相关专业。
  • 荣誉:阿里云博客专家认证、腾讯开发者社区优质创作者,在CTF省赛校赛多次取得好成绩。
  • 跨领域学习,喜欢摄影、弹吉他、咏春拳。文章深入浅出、语言风趣;爱吃必胜客社区创立者,旨在“发现美 欣赏美

  • 🏆 学习系列专栏
    。🏅 Python学习宝库
    。🏅 网络安全学习宝库

在这里插入图片描述

在这里插入图片描述

文章目录

  • ⭐️前言
  • ⭐️代码举例
    • 🌟 买票程序初始代码
  • ⭐️改进
    • 🌟 多学一点:多线程编程,为什么要调用join方法
  • ⭐️最终版-用类方式实现

⭐️前言

在这里插入图片描述

首先我们笼统来看几个改善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]-numsreturn numselse:print("没票了")return -1i+=1print("今天没票了%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]-numsreturn numselse:print("没票了")return -1i+=1print("今天没票了%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]-numsreturn numselse:print("没票了")return -1i+=1print("今天没票了%s"%(name))return -1class MThread(threading.Thread):# 子类继承def __init__(self,target,args):# 定义构造函数initthreading.Thread.__init__(self)# 继承父类的initself.target=targetself.args=argsdef 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()

http://www.ppmy.cn/news/37964.html

相关文章

stm32f10x系列芯片信息

stm32f10x系列芯片信息 STM32F103微控制器采用Cortex-M3内核,CPU最高速度达72 MHz。该产品系列具有16KB ~ 1MB Flash、多种控制外设、USB全速接口和CAN。 引脚及其容量大小关系 Flash memory size / RAM size(byte):flash内存大…

美国Linux服务器系统()与[ ]括号的作用

美国Linux服务器系统在使用过程中会很多需要使用到括号的时候,而不同括号在美国Linux服务器系统中会有不同的作用,本文小编就来介绍下美国Linux服务器系统中括号( )和[ ]括号的作用。 一、括号( )的作用 1、单小括号 ( ) 1)命令组 括号中的命令将会新…

[软件测试]软件测试的原则及软件质量

十大原则: 测试是证伪而不是证真。测试应当有重点。事先定义好产品的质量标准,确定测试用例用例输出结果。软件项目一启动,软件测试也就开始了。穷举测试是不可能的。第三方测试会更加客观,更有效。 软件测试计划是做好软件测试工…

idea调试接口Http Client很好但是Apifox Helper更香呀

Http Client与Apifox Helper鱼与熊掌不可得兼 🛵...调试接口Http ClientApifox其实每个人都有自己的不如意,只是有的人站在阳光下哭花了脸,有的人却躲在暗地里开出了花 调试接口 还在用 postman 调试接口? 也不是不行, 只是我觉得Http Cli…

《程序员面试金典(第6版)》面试题 08.03. 魔术索引

题目描述 魔术索引。 在数组A[0…n-1]中,有所谓的魔术索引,满足条件A[i] i。给定一个有序整数数组,编写一种方法找出魔术索引,若有的话,在数组A中找出一个魔术索引,如果没有,则返回-1。若有多…

力推美团企业版 美团究竟意欲何为?

已经拥有930万活跃商家的美团公司,正在充分整合自身的“供应链”优势,冲向B端市场。 3月31日,据36氪消息显示,美团将于近期正式上线面向To B市场的业务“美团企业版”,定位企业消费赛道。美团企业版会为企业客户提供消…

线段树简介

1、线段树是什么? 线段树(Segment Tree)是一种经典的数据结构,它是一颗二叉树,每个节点都代表区间。线段树用于解决静态区间问题和动态区间问题。 它的主要思想是将区间划分成若干个小区间,每个节点代表一…

Leveldb源码解读------Memtable(跳表)详解

在leveldb中的memtable实际上是对核心数据结构skipList做了一个包装,并对外提供了接口。 使用让我们一起来研究一下跳表 为什么使用跳表 因为memtable为了更快的查询,是一个sortmap要求。一般会采用红黑树,不过LevelDB采用的是Skiplist。S…