成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python 中快的循環方式,你知道幾種?

開發 前端
生成器是惰性的,不會一下子生成 1 億個數字,而列表推導式會一下子申請全部的數字,內存占有較高不說,還不能有效地利用緩存,因此性能稍差。

大家好,我是 somenzz,今天我們來研究一下 Python 中最快的循環方式。

各種姿勢

比如說有一個簡單的任務,就是從 1 累加到 1 億,我們至少可以有 7 種方法來實現,列舉如下:

1、while 循環

def while_loop(n=100_000_000):
i = 0
s = 0
while i < n:
s += i
i += 1
return s

2、for 循環

def for_loop(n=100_000_000):
s = 0
for i in range(n):
s += i
return s

3、sum range

def sum_range(n=100_000_000):
return sum(range(n))

4、sum generator(生成器)

def sum_generator(n=100_000_000):
return sum(i for i in range(n))

5、sum list comprehension(列表推導式)

def sum_list_comp(n=100_000_000):
return sum([i for i in range(n)])

6、sum numpy

import numpy
def sum_numpy(n=100_000_000):
return numpy.sum(numpy.arange(n, dtype=numpy.int64))

7、sum numpy python range

import numpy
def sum_numpy_python_range(n=100_000_000):
return numpy.sum(range(n))

上述 7 種方法得到的結果是一樣的,但是消耗的時間卻各不相同,你可以猜測一下哪一個方法最快,然后看下面代碼的執行結果:

import timeit

def main():
l_align = 25
print(f'{"1、while 循環":<{l_align}} {timeit.timeit(while_loop, number=1):.6f}')
print(f"{'2、for 循環':<{l_align}} {timeit.timeit(for_loop, number=1):.6f}")
print(f'{"3、sum range":<{l_align}} {timeit.timeit(sum_range, number=1):.6f}')
print(f'{"4、sum generator":<{l_align}} {timeit.timeit(sum_generator, number=1):.6f}')
print(f'{"5、sum list comprehension":<{l_align}} {timeit.timeit(sum_list_comp, number=1):.6f}')
print(f'{"6、sum numpy":<{l_align}} {timeit.timeit(sum_numpy, number=1):.6f}')
print(f'{"7、sum numpy python range":<{l_align}} {timeit.timeit(sum_numpy_python_range, number=1):.6f}')

if __name__ == '__main__':
main()

執行結果如下所示:

比較快的方式

for 比 while 塊

for 和 while 本質上在做相同的事情,但是 while 是純 Python 代碼,而 for 是調用了 C 擴展來對變量進行遞增和邊界檢查,我們知道 CPython 解釋器就是 C 語言編寫的,Python 代碼要比 C 代碼慢,而 for 循環代表 C,while 循環代表 Python,因此 for 比 while 快。

numpy 內置的 sum 要比 Python 的 sum 快

numpy 主要是用 C 編寫的,相同的功能,肯定是 numpy 的快,類似的,numpy 的 arange 肯定比 Python 的 range 快。

交叉使用會更慢

numpy 的 sum 與 Python 的 range 結合使用,結果耗時最長,見方法 7。最好是都使用 numpy 包來完成任務,像方法 6。

生成器比列表推導式更快

生成器是惰性的,不會一下子生成 1 億個數字,而列表推導式會一下子申請全部的數字,內存占有較高不說,還不能有效地利用緩存,因此性能稍差。

責任編輯:武曉燕 來源: Python七號
相關推薦

2021-05-07 16:19:36

異步編程Java線程

2024-05-10 07:44:23

C#進程程序

2024-02-05 12:08:07

線程方式管理

2021-08-05 07:28:25

Java實現方式

2019-07-23 17:52:59

Spring BootJava開發

2025-01-21 10:04:40

Java并發阻塞隊列

2019-07-23 15:56:56

Spring Boot部署servlet

2023-10-30 11:53:37

繼承JS父類

2023-05-30 14:54:17

Python循環語句工具

2024-11-04 09:39:08

Java?接口Thread?類

2024-06-12 08:05:06

2024-04-24 11:24:43

C#數據去重

2020-11-16 09:15:07

MYSQL

2020-09-07 08:00:48

2024-09-20 08:04:54

2023-12-27 12:12:35

NumPy函數數組

2022-06-27 07:32:00

JavaArrayList語法糖

2020-09-28 14:24:09

字典Dictionary遍歷

2021-07-09 07:00:27

SpringbootServlet容器

2021-01-19 11:56:19

Python開發語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品成人一区 | 国产中的精品av涩差av | 欧美精品 在线观看 | 欧美日韩精品久久久免费观看 | 日日夜夜草 | 国产日韩欧美中文 | 高清不卡毛片 | 精品av久久久久电影 | 亚洲精品视频免费 | 国产精品美女久久久久aⅴ国产馆 | 日韩在线免费视频 | 91 久久 | 亚洲第一成人影院 | 日产久久| 久久国产激情视频 | 在线成人免费观看 | 国产精品一区二区三级 | 九九热在线免费观看 | 国产一级特黄视频 | 一区二区三区四区不卡 | 亚洲精品成人网 | 午夜精品久久久久久久久久久久久 | 特黄毛片 | 国产一区二区精华 | 一区二区三区中文字幕 | 九色网址 | 蜜桃免费av | 精品亚洲二区 | 亚洲国产精品久久久 | 午夜天堂精品久久久久 | 亚洲视频在线观看 | 秋霞在线一区二区 | 精品欧美一区二区三区久久久 | 国产精品美女久久久久久免费 | 成人在线一区二区 | 日韩中文字幕视频 | 国产精品不卡视频 | 日韩中文字幕在线免费 | 男女污污网站 | 国内毛片毛片毛片毛片 | 免费在线观看一区二区三区 |