对Python中队列三种实现方式的测试

news2024/12/27 21:53:56

一、结论

'''
本程序模拟比较队列的三种情况:
    一、deque当作队列使用;
    二、queue当作队列使用;
    三、list当作队列使用。
结论:
    Python队列可以用deque、queue、list实现,其中list极慢、queue较慢,deque最快。
    经测试结论为:deque比queue快20倍以上,deque比list快1000倍以上,queue比list快40倍以上。

    测试说明:云服务器2C4G,CentOs7.9为测试环境,数据量为100 0000,结论仅供参考。
'''

二、测试数据

三、测试过程

'''
本程序模拟比较队列的三种情况:
    一、deque当作队列使用;
    二、queue当作队列使用;
    三、list当作队列使用。
结论:
    Python队列可以用deque、queue、list实现,其中list极慢、queue较慢,deque最快。
    经测试结论为:deque比queue快20倍以上,deque比list快1000倍以上,queue比list快40倍以上。
'''
from collections import *
from queue import *
from time import *
n = 1000000
class test():
    
    def test_deque(self):
        '''
            test the time spent on executing deque.
        '''
        global n
        start = time()
        q = deque()
        for i in range(n):
            q.append(i)
        for i in range(n):
            q.popleft()
        end = time()
        print('The time spent on executing deque is: %f' % (end - start))
        return end - start

    def test_queue(self):
        '''
            test the time spent on executing queue.
        '''
        global n
        start = time()
        q = Queue()
        for i in range(n):
            q.put(i)
        for i in range(n):
            q.get()
        end = time()
        print('The time spent on executing queue is: %f' % (end - start))
        return end - start

    def test_list(self):
        '''
            test the time spent on executing list.
        '''
        start = time()
        global n
        q = []
        for i in range(n):
            q.append(i)
        for i in range(n):
            q.pop(0)
        end = time()
        print('The time spent on executing list is: %f' % (end - start))
        return end - start
    def so_the_result_of_test_is(self):
        global n
        deque_time = self.test_deque()
        queue_time = self.test_queue()
        list_time = self.test_list()
        
        compare_deque_queue = queue_time / deque_time
        compare_deque_list = list_time / deque_time
        compare_queue_list = list_time / queue_time
        
        print('When the data volume is ' + str(n) + ', queque is slower than deque:%f' % compare_deque_queue)
        print('When the data volume is ' + str(n) + ', list is slower than deque: %f' % compare_deque_list)
        print('When the data volume is ' + str(n) + ', list is slower than queue: %f' % compare_queue_list)

t = test()
t.so_the_result_of_test_is()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2266609.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【VScode】第三方GPT编程工具-CodeMoss安装教程

一、CodeMoss是什么? CodeMoss是一款集编程、学习和办公于一体的高效工具。它兼容多种主流平台,包括VSCode、IDER、Chrome插件、Web和APP等,支持插件安装,尤其在VSCode和IDER上的表现尤为出色。无论你是编程新手还是资深开发者&a…

Unity中如何修改Sprite的渲染网格

首先打开SpriteEditor 选择Custom OutLine,点击Genrate 则在图片边缘会出现边缘线,调整白色小方块可以调整边缘 调整后,Sprite就会按照调整后的网格渲染了。 如何在UI中使用? 只要在UI的Image组件中选择Use Sprite Mesh 即可 结果&#xff1…

【机器学习】探索机器学习与人工智能:驱动未来创新的关键技术

探索机器学习与人工智能:驱动未来创新的关键技术 前言:人工智能的核心技术深度学习:自然语言处理(NLP):计算机视觉: 机器学习与人工智能的驱动创新医疗健康领域金融行业智能制造与工业互联网智慧…

Visual Studio Code(VS Code)配置C/C++环境

一、Visual Studio Code安装 Visual Studio Code,下文中简称为VS Code的详细安装方法请参考VSCode安装教程(超详细)-CSDN博客 二、MinGW编译器下载与配置 1、MinGW介绍 MinGW(Minimalist GNU for Windows)是一款用于Windows 平台的轻…

Postman接口测试01|接口测试基础概念、http协议、RESTful风格、接口文档

目录 一、接口测试基础概念 1、什么是接口 2、接口的类型 3、什么是接口测试 4、为什么要做接口测试 5、接口测试的实现方式 6、什么是自动化接口测试? 二、接口返回的数据格式 1、三种格式 2、Json 三、接口协议 1、webservice协议 2、dubbo协议 3、…

HDR视频技术之十一:HEVCH.265 的 HDR 编码方案

前文我们对 HEVC 的 HDR 编码优化技术做了介绍,侧重编码性能的提升。 本章主要阐述 HEVC 中 HDR/WCG 相关的整体编码方案, 包括不同应用场景下的 HEVC 扩展编码技术。 1 背景 HDR 信号一般意味着使用更多比特,一般的 HDR 信号倾向于使用 10…

ThinkPHP 8开发环境安装

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《ThinkPHP 8高效构建Web应用 夏磊 编程与应用开发丛书 清华大学出版社》【摘要 书评 试读】- 京东图书 1. 安装PHP8 Windows系统用户可以前往https://windows.php.net/downloads/releases/archives/下载PHP 8.0版本&am…

CAN201 Introduction to Networking(计算机网络)Pt.2 传输层

文章目录 3. Transport Layer(传输层)3.1 Multiplexing and demultiplexing(多路复用和多路分解)3.2 Connectionless transport:UDP3.3 Principles of reliable data transfer3.4 Pipelined communication3.5 TCP: con…

linux系统上SQLPLUS的重“大”发现

SQL plus版本: [oraclepg-xc2 ~]$ sqlplus -v SQL*Plus: Release 19.0.0.0.0 - Production Version 19.3.0.0.0 操作系统:CentOS Linux 7 (Core) 数据库:Oracle 19c Version 19.3.0.0.0 同样的SQL脚本在windos CMD sqlplus 执行没问题。…

Unity中实现人物残影效果

今天火柴人联盟3公测了,看到一个残影的效果,很有意思,上网查询了一下实现方式, 实现思路: 将角色的网格复制出来,然后放置到新建的物体的MeshFilter组件上,每隔几十毫秒在玩家的位置生成一个&a…

mysql mmm和mha对比

本文简单介绍MySQL的两个high availability方案,MMM和MHA。 MMM MMM(Master-Master replication managerfor Mysql)的基本组成如下, 主节点master1:承载写流量备主节点master2:replicate主节点master1的写流量,在主节…

探秘“香水的 ChatGPT”:AI 开启嗅觉奇幻之旅!

你没有看错,AI也能闻到味道了!这是一家名为Osmo公司公布的信息,他们成功创造出了由AI生成的李子味道,快跟着小编一探究竟吧~ 【图片来源于网络,侵删】 Osmo公司的这项技术,通过分析香味的化学成分和人类嗅…

uniapp实现为微信小程序扫一扫的功能

引言 随着微信小程序的快速发展,越来越多的开发者开始关注和学习微信小程序的开发。其中,微信小程序的扫一扫功能是非常常用且实用的功能之一。通过扫描二维码,用户可以获取到相关的信息或者实现特定的功能。 正文 在过去,开发者需要使用微信开发者工具以及相关的开发文档…

网络ip地址改成什么比较好

在数字化时代,网络IP地址作为设备在网络中的唯一标识,扮演着至关重要的角色。然而,随着网络环境的日益复杂和网络安全问题的频发,许多用户开始考虑更改自己的网络IP地址,以期获得更好的网络体验和安全保障。那么&#…

iOS从Matter的设备认证证书中获取VID和PID

设备认证证书也叫 DAC, 相当于每个已经认证的设备的标识。包含了 VID 和 PID. VID: Vendor ID ,标识厂商 PID: Product ID, 标识设备的 根据 Matter 对于设备证书的规定,DAC证书subject应该包含VID 和 PID. 可通过解析 X509 证书读取subject…

聊一聊 C#线程池 的线程动态注入

提高注入速度的两种方法 1. 降低GateThread的延迟时间 上一篇跟大家聊过 Result 默认情况下GateThread每秒会注入4个,底层逻辑是由 Blocking.MaxDelayMs250ms 变量控制的,言外之意就是能不能减少这个变量的值呢?当然可以的,这里我…

【嵌入式C语言】指针数组结构体

指针与数组 指针与数组指针数组数组指针 多维数组数组名的保存 结构体定义结构体定义结构体变量使用typedef简化结构体声明访问结构体成员结构体内存分配字节对齐位域定义位域位域的限制示例 指针与数组 指针数组和数组指针是两个不同的概念,它们涉及到指针和数组的…

HarmonyOS NEXT 实战之元服务:静态案例效果(二)

背景: 前几篇学习了元服务,后面几期就让我们开发简单的元服务吧,里面丰富的内容大家自己加,本期案例 仅供参考 先上本期效果图 ,里面图片自行替换 效果图代码案例如下: Index里面实现 import { authent…

Android Studio超级详细讲解下载、安装配置教程(建议收藏)

博主介绍:✌专注于前后端、机器学习、人工智能应用领域开发的优质创作者、秉着互联网精神开源贡献精神,答疑解惑、坚持优质作品共享。本人是掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战,深受全网粉丝喜爱与支持✌有…

从安全角度看 SEH 和 VEH

从安全角度看 SEH 和 VEH 异常处理程序是处理程序中不可预见的错误的基本方法之一 https://learn.microsoft.com/en-us/dotnet/csharp/fundamentals/exceptions/ SEH——结构化异常处理程序 就其工作方式而言,异常处理程序与其他处理程序相比相当基础&#xff0…