极其无聊的测试——python中不同相差数百行的代码实现是否影响执行时间

本文主要是介绍极其无聊的测试——python中不同相差数百行的代码实现是否影响执行时间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:在用python的turtle功能画五角星时,代码如下:

import turtle as t
import math
import time
start =time.time()t.speed(0)
t.pendown()t.left(72)
t.fd(100)t.right(144)
t.fd(100)t.left(72)
t.fd(100)t.right(144)
t.fd(100)t.left(72)
t.fd(100)t.right(144)
t.fd(100)t.left(72)
t.fd(100)t.right(144)
t.fd(100)t.left(72)
t.fd(100)t.right(144)
t.fd(100)
end= time.time()print('Running time: %s Seconds'%(end-start))
#Running time: 0.7766807079315186 Seconds

很容易发现代码可以简化用循环语句实现,代码如下


import turtle as t
import math
import time
start =time.time()t.speed(0)
t.pendown()for i in range(5):for y in range(1):t.left(72)t.fd(100)t.right(144)t.fd(100)end= time.time()print('Running time: %s Seconds'%(end-start))
#Running time: 0.8124051094055176 Seconds

可以看到代码极其为缩短
但是可以看到两种实现方式下的代码的执行过程时间稍微有些许不同
但是由于时间很短,几乎可以归于误差
于是由画五角星变为画200角“星”

循环方式实现代码如下

import turtle as t
import math
import time
start =time.time()t.speed(0)
t.penup()
t.goto(0,100)
t.pendown()
for i in range(200):for y in range(1):t.left(89.1)t.fd(10)t.right(90.9)t.fd(10)end= time.time()print('循环画Running time: %s Seconds'%(end-start))
import turtle as t
import math
import time
start =time.time()t.left(89.1)
t.fd(10)
t.right(90.9)
t.fd(10)t.left(89.1)
t.fd(10)
t.right(90.9)
t.fd(10)t.left(89.1)
t.fd(10)
t.right(90.9)
t.fd(10)
(
一共200次复制粘贴
t.left(89.1)
t.fd(10)
t.right(90.9)
t.fd(10)end= time.time()print('直接画Running time: %s Seconds'%(end-start))

测试时间截图如下
在这里插入图片描述
可以看到除了第一个作为较大偏差舍去外,其他多次测试结果的时间不分上下,基本可以认为是误差。
对硬件较为熟悉的朋友应该知道CPU的频率一般是波动的,测试期间基本在4.10GHZ附近波动,所以在200次的循环下基本上图中的时间相差可以认为是误差
结论:所以现在只能认为在turtle画图函数调用过程中,上面两种代码实现方式尽管代码量相差数百倍,但代码量不影响代码的运行时间,可以认为更加影响代码时间的是画图这个动作本身的时间

这篇关于极其无聊的测试——python中不同相差数百行的代码实现是否影响执行时间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/914976

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time