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

Python 哪種方式循環(huán)最快,或許顛覆你的認(rèn)知!

開(kāi)發(fā) 后端
while 和 for 是 Python 中常用的兩種實(shí)現(xiàn)循環(huán)的關(guān)鍵字,它們的運(yùn)行效率實(shí)際上是有差距的。

眾所周知,Python 不是一種執(zhí)行效率較高的語(yǔ)言。此外在任何語(yǔ)言中,循環(huán)都是一種非常消耗時(shí)間的操作。假如任意一種簡(jiǎn)單的單步操作耗費(fèi)的時(shí)間為 1 個(gè)單位,將此操作重復(fù)執(zhí)行上萬(wàn)次,最終耗費(fèi)的時(shí)間也將增長(zhǎng)上萬(wàn)倍。

while 和 for 是 Python 中常用的兩種實(shí)現(xiàn)循環(huán)的關(guān)鍵字,它們的運(yùn)行效率實(shí)際上是有差距的。比如下面的測(cè)試代碼:

import timeit
def while_loop(n=100_000_000):
i = 0
s = 0
while i < n:
s += i
i += 1
return s
def for_loop(n=100_000_000):
s = 0
for i in range(n):
s += i
return s
def main():
print('while loop\t\t', timeit.timeit(while_loop, number=1))
print('for loop\t\t', timeit.timeit(for_loop, number=1))
if __name__ == '__main__':
main()
# => while loop 4.718853999860585
# => for loop 3.211570399813354

這是一個(gè)簡(jiǎn)單的求和操作,計(jì)算從 1 到 n 之間所有自然數(shù)的總和。可以看到 for 循環(huán)相比 while 要快 1.5 秒。

其中的差距主要在于兩者的機(jī)制不同。

在每次循環(huán)中,while 實(shí)際上比 for 多執(zhí)行了兩步操作:邊界檢查和變量 i 的自增。即每進(jìn)行一次循環(huán),while 都會(huì)做一次邊界檢查 (while i < n)和自增計(jì)算(i +=1)。這兩步操作都是顯式的純 Python 代碼。

for 循環(huán)不需要執(zhí)行邊界檢查和自增操作,沒(méi)有增加顯式的 Python 代碼(純 Python 代碼效率低于底層的 C 代碼)。當(dāng)循環(huán)的次數(shù)足夠多,就出現(xiàn)了明顯的效率差距。

可以再增加兩個(gè)函數(shù),在 for 循環(huán)中加上不必要的邊界檢查和自增計(jì)算:

import timeit
def while_loop(n=100_000_000):
i = 0
s = 0
while i < n:
s += i
i += 1
return s
def for_loop(n=100_000_000):
s = 0
for i in range(n):
s += i
return s
def for_loop_with_inc(n=100_000_000):
s = 0
for i in range(n):
s += i
i += 1
return s
def for_loop_with_test(n=100_000_000):
s = 0
for i in range(n):
if i < n:
pass
s += i
return s
def main():
print('while loop\t\t', timeit.timeit(while_loop, number=1))
print('for loop\t\t', timeit.timeit(for_loop, number=1))
print('for loop with increment\t\t',
timeit.timeit(for_loop_with_inc, number=1))
print('for loop with test\t\t', timeit.timeit(for_loop_with_test, number=1))
if __name__ == '__main__':
main()
# => while loop 4.718853999860585
# => for loop 3.211570399813354
# => for loop with increment 4.602369500091299
# => for loop with test 4.18337869993411

可以看出,增加的邊界檢查和自增操作確實(shí)大大影響了 for 循環(huán)的執(zhí)行效率。

前面提到過(guò),Python 底層的解釋器和內(nèi)置函數(shù)是用 C 語(yǔ)言實(shí)現(xiàn)的。而 C 語(yǔ)言的執(zhí)行效率遠(yuǎn)大于 Python。

對(duì)于上面的求等差數(shù)列之和的操作,借助于 Python 內(nèi)置的 sum 函數(shù),可以獲得遠(yuǎn)大于 for 或 while 循環(huán)的執(zhí)行效率。

import timeit
def while_loop(n=100_000_000):
i = 0
s = 0
while i < n:
s += i
i += 1
return s
def for_loop(n=100_000_000):
s = 0
for i in range(n):
s += i
return s
def sum_range(n=100_000_000):
return sum(range(n))
def main():
print('while loop\t\t', timeit.timeit(while_loop, number=1))
print('for loop\t\t', timeit.timeit(for_loop, number=1))
print('sum range\t\t', timeit.timeit(sum_range, number=1))
if __name__ == '__main__':
main()
# => while loop 4.718853999860585
# => for loop 3.211570399813354
# => sum range 0.8658821999561042

可以看到,使用內(nèi)置函數(shù) sum 替代循環(huán)之后,代碼的執(zhí)行效率實(shí)現(xiàn)了成倍的增長(zhǎng)。

內(nèi)置函數(shù) sum 的累加操作實(shí)際上也是一種循環(huán),但它由 C 語(yǔ)言實(shí)現(xiàn),而 for 循環(huán)中的求和操作是由純 Python 代碼 s += i 實(shí)現(xiàn)的。C > Python。

再拓展一下思維。小時(shí)候都聽(tīng)說(shuō)過(guò)童年高斯巧妙地計(jì)算 1 到 100 之和的故事。1…100 之和等于 (1 + 100) * 50。這個(gè)計(jì)算方法同樣可以應(yīng)用到上面的求和操作中。

import timeit
def while_loop(n=100_000_000):
i = 0
s = 0
while i < n:
s += i
i += 1
return s
def for_loop(n=100_000_000):
s = 0
for i in range(n):
s += i
return s
def sum_range(n=100_000_000):
return sum(range(n))
def math_sum(n=100_000_000):
return (n * (n - 1)) // 2
def main():
print('while loop\t\t', timeit.timeit(while_loop, number=1))
print('for loop\t\t', timeit.timeit(for_loop, number=1))
print('sum range\t\t', timeit.timeit(sum_range, number=1))
print('math sum\t\t', timeit.timeit(math_sum, number=1))
if __name__ == '__main__':
main()
# => while loop 4.718853999860585
# => for loop 3.211570399813354
# => sum range 0.8658821999561042
# => math sum 2.400018274784088e-06

最終 math sum 的執(zhí)行時(shí)間約為 2.4e-6,縮短了上百萬(wàn)倍。這里的思路就是,既然循環(huán)的效率低,一段代碼要重復(fù)執(zhí)行上億次。

索性直接不要循環(huán),通過(guò)數(shù)學(xué)公式,把上億次的循環(huán)操作變成只有一步操作。效率自然得到了空前的加強(qiáng)。

最后的結(jié)論(有點(diǎn)謎語(yǔ)人):

實(shí)現(xiàn)循環(huán)的最快方式—— —— ——就是不用循環(huán)

對(duì)于 Python 而言,則盡可能地使用內(nèi)置函數(shù),將循環(huán)中的純 Python 代碼降到最低。

責(zé)任編輯:龐桂玉 來(lái)源: Python與AI社區(qū)
相關(guān)推薦

2022-06-21 15:00:01

Python語(yǔ)言循環(huán)方式

2022-06-27 07:32:00

JavaArrayList語(yǔ)法糖

2021-12-06 09:40:44

Pythonforwhile

2024-06-28 12:54:45

2018-01-13 23:17:55

谷歌研究報(bào)告團(tuán)隊(duì)建設(shè)

2022-05-27 06:57:50

Python循環(huán)方式生成器

2023-10-13 08:52:19

遠(yuǎn)程Bean類型

2021-04-27 09:00:00

PythonIDE開(kāi)發(fā)

2014-11-27 17:10:46

身份認(rèn)證認(rèn)知指紋生物識(shí)別

2018-03-12 12:26:23

2017-08-08 14:16:56

區(qū)塊鏈數(shù)據(jù)IT

2018-06-04 14:10:29

2020-10-26 14:03:07

混合云云計(jì)算云遷移

2013-10-17 15:30:04

方法調(diào)用object

2015-11-10 17:10:53

創(chuàng)業(yè)思考方式

2019-09-03 10:59:28

SQL索引語(yǔ)句

2020-05-26 12:32:30

Python模板語(yǔ)言編程語(yǔ)言

2022-08-16 16:00:05

Python

2021-07-30 10:12:54

密碼互聯(lián)網(wǎng)安全密碼策略

2019-12-04 07:39:07

MySQL索引數(shù)據(jù)庫(kù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 三区在线观看 | a网站在线观看 | 91国自视频 | 日韩欧美一区二区三区在线播放 | 国产在线精品一区 | 97操操 | 亚洲在线 | 久久久久久久一区 | 天堂在线中文字幕 | 久草新在线 | 欧美二区在线 | 亚洲人成人一区二区在线观看 | 久久亚洲一区 | 欧美啪啪 | 天天操天天干天天爽 | 我要看黄色录像一级片 | 在线免费观看黄色 | 一区二区不卡 | 亚洲精品久久久久中文字幕欢迎你 | 黄在线| 日本三级全黄三级a | 亚洲视频一区在线 | 黄色大片在线 | 国产精品乱码一二三区的特点 | 日韩久久综合 | 日本成人在线免费视频 | 最新国产精品 | 黄免费观看 | 人人叉 | 国产日韩免费观看 | 亚洲日韩视频 | 成人免费视频网站在线看 | 午夜视频在线播放 | 日本a∨精品中文字幕在线 亚洲91视频 | 欧美一级欧美一级在线播放 | 亚洲午夜视频 | 国产日韩精品视频 | 草久久久 | 亚洲男人网 | 国产成在线观看免费视频 | 日日噜噜噜夜夜爽爽狠狠视频97 |