精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

詳解增強算術賦值:“-=”操作是怎么實現的?

開發 后端
Python 有一種叫做增強算術賦值(augmented arithmetic assignment)的東西。可能你不熟悉這個叫法,其實就是在做數學運算的同時進行賦值,例如 a -= b 就是減法的增強算術賦值。

[[341654]]

序言

本文是 Python語法糖 系列文章之一。最新的源代碼可以在 desugar 項目中找到(https://github.com/brettcannon/desugar)。

 

介紹

Python 有一種叫做增強算術賦值(augmented arithmetic assignment)的東西。可能你不熟悉這個叫法,其實就是在做數學運算的同時進行賦值,例如 a -= b 就是減法的增強算術賦值。

增強賦值是在 Python 2.0 版本中 加入進來的。(譯注:在 PEP-203 中引入)

剖析 -=

因為 Python 不允許覆蓋式賦值,所以相比其它有特殊/魔術方法的操作,它實現增強賦值的方式可能跟你想象的不完全一樣。

首先,要知道a -= b在語義上與 a = a-b 相同。但也要意識到,如果你預先知道要將一個對象賦給一個變量名,相比a - b 的盲操作,就可能會更高效。

例如,最起碼的好處是可以避免創建一個新對象:如果可以就地修改一個對象,那么返回 self,就比重新構造一個新對象要高效。

因此,Python 提供了一個__isub__() 方法。如果它被定義在賦值操作的左側(通常稱為 lvalue),則會調用右側的值(通常稱為 rvalue )。所以對于a -= b ,就會嘗試去調用 a.__isub__(b)。

如果調用的結果是 NotImplemented,或者根本不存在結果,那么 Python 會退回到常規的二元算術運算:a - b。(譯注:作者關于二元運算的文章,譯文在此)

最終無論用了哪種方法,返回值都會被賦值給 a。

下面是簡單的偽代碼,a -= b 被分解成:

  1. # 實現 a -= b 的偽代碼 
  2. if hasattr(a, "__isub__"): 
  3.     _value = a.__isub__(b) 
  4.     if _value is not NotImplemented: 
  5.         a = _value 
  6.     else
  7.         a = a - b 
  8.     del _value 
  9.  else
  10.      a = a - b 

歸納這些方法

由于我們已經實現了二元算術運算,因此歸納增強算術運算并不太復雜。

通過傳入二元算術運算函數,并做一些自省(以及處理可能發生的 TypeError),它可以被漂亮地歸納成:

  1. def _create_binary_inplace_op(binary_op: _BinaryOp) -> Callable[[AnyAny], Any]: 
  2.  
  3.     binary_operation_name = binary_op.__name__[2:-2] 
  4.     method_name = f"__i{binary_operation_name}__" 
  5.     operator = f"{binary_op._operator}=" 
  6.  
  7.     def binary_inplace_op(lvalue: Any, rvalue: Any, /) -> Any
  8.         lvalue_type = type(lvalue) 
  9.         try: 
  10.             method = debuiltins._mro_getattr(lvalue_type, method_name) 
  11.         except AttributeError: 
  12.             pass 
  13.         else
  14.             value = method(lvalue, rvalue) 
  15.             if value is not NotImplemented: 
  16.                 return value 
  17.         try: 
  18.             return binary_op(lvalue, rvalue) 
  19.         except TypeError as exc: 
  20.             # If the TypeError is due to the binary arithmetic operator, suppress 
  21.             # it so we can raise the appropriate one for the agumented assignment. 
  22.             if exc._binary_op != binary_op._operator: 
  23.                 raise 
  24.         raise TypeError( 
  25.             f"unsupported operand type(s) for {operator}: {lvalue_type!r} and {type(rvalue)!r}" 
  26.         ) 
  27.  
  28.     binary_inplace_op.__name__ = binary_inplace_op.__qualname__ = method_name 
  29.     binary_inplace_op.__doc__ = ( 
  30.         f"""Implement the augmented arithmetic assignment `a {operator} b`.""" 
  31.     ) 
  32.     return binary_inplace_op 

這使得定義的 -= 支持 _create_binary_inplace_op(__ sub__),且可以推斷出其它內容:函數名、調用什么 __i*__ 函數,以及當二元算術運算出問題時,該調用哪個可調用對象。

我發現幾乎沒有人使用**=

在寫本文的代碼時,我碰上了 **= 的一個奇怪的測試錯誤。在所有確保 __pow__ 會被適當地調用的測試中,有個測試用例對于 Python 標準庫中的operator 模塊卻是失敗。

我的代碼通常沒問題,如果代碼與 CPython 的代碼之間存在差異,通常會意味著是我哪里出錯了。

但是,無論我多么仔細地排查代碼,我都無法定位出為什么我的測試會通過,而標準庫則失敗。

我決定深入地了解 CPython 內部發生了什么。從反匯編字節碼開始:

  1. >>> def test(): a **= b 
  2. ...  
  3. >>> import dis 
  4. >>> dis.dis(test) 
  5.   1           0 LOAD_FAST                0 (a) 
  6.               2 LOAD_GLOBAL              0 (b) 
  7.               4 INPLACE_POWER 
  8.               6 STORE_FAST               0 (a) 
  9.               8 LOAD_CONST               0 (None) 
  10.              10 RETURN_VALUE 

通過它,我找到了在 eval 循環中的INPLACE_POWER:

  1. case TARGET(INPLACE_POWER): { 
  2.        PyObject *exp = POP(); 
  3.        PyObject *base = TOP(); 
  4.        PyObject *res = PyNumber_InPlacePower(base, exp, Py_None); 
  5.        Py_DECREF(base); 
  6.        Py_DECREF(exp); 
  7.        SET_TOP(res); 
  8.        if (res == NULL
  9.            goto error; 
  10.        DISPATCH(); 
  11.    } 

出處:https://github.com/python/cpython/blob/v3.8.3/Python/ceval.c#L1677

然后找到PyNumber_InPlacePower():

  1. PyObject * 
  2. PyNumber_InPlacePower(PyObject *v, PyObject *w, PyObject *z) 
  3.     if (v->ob_type->tp_as_number && 
  4.         v->ob_type->tp_as_number->nb_inplace_power != NULL) { 
  5.         return ternary_op(v, w, z, NB_SLOT(nb_inplace_power), "**="); 
  6.     } 
  7.     else { 
  8.         return ternary_op(v, w, z, NB_SLOT(nb_power), "**="); 
  9.     } 

出處:https://github.com/python/cpython/blob/v3.8.3/Objects/abstract.c#L1172

松了口氣~代碼顯示如果定義了__ipow__,則會調用它,但是只在沒有__ipow__ 時,才會調用__pow__。

然而,正確的做法應該是:如果調用__ipow__ 時出問題,返回了 NotImplemented 或者根本不存在返回,那么就應該調用 __pow__ 和__rpow__。

換句話說,當存在__ipow__時,以上代碼會意外地跳過 a**b 的后備語義!

實際上,大約11個月前,這個問題被部分地發現,并提交了 bug。我修復了該問題,并在 python-dev 上作了說明。

截至目前,這似乎會在 Python 3.10 中修復,我們還需要在 3.8 和 3.9 的文檔中添加關于 **= 有 bug 的通知(該問題可能很早就有了,但較舊的 Python 版本已處于僅安全維護模式,因此文檔不會變更)。

 

修復的代碼很可能不會被移植,因為它是語義上的變化,并且很難判斷是否有人意外地依賴了有問題的語義。但是這個問題花了很長時間才被注意到,這就表明 **= 的使用并不廣泛,否則問題早就被發現了。

原題 | Unravelling augmented arithmetic assignment

 

作者 | Brett Cannon

本文轉載自微信公眾號「Python貓」,可以通過以下二維碼關注。轉載本文請聯系Python貓公眾號。   

 

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

2024-09-10 12:15:24

2010-08-27 09:06:49

F#

2024-08-22 10:11:00

字典取值源碼

2022-09-09 15:32:46

intC語言原子操作

2022-07-01 11:07:56

int原子操作代碼

2010-01-25 13:43:09

C++算術編碼

2021-12-15 10:54:42

數據增強機器學習數據

2024-05-31 09:31:00

2009-09-07 13:25:56

Silverlight

2010-03-01 16:31:58

WCF實現SOA

2009-09-09 18:57:26

C# 加密TripleDES

2024-09-18 13:49:42

2009-02-17 18:52:06

網絡虛擬化路由系統數據中心

2021-08-30 22:38:47

VscodeMarkdown預覽

2021-04-19 11:23:29

操作系統計算機DOS

2022-11-01 11:22:38

2019-10-21 13:12:41

數據分析增強分析人工智能

2025-03-05 09:37:03

2025-01-20 07:00:00

2010-04-01 17:43:56

Oracle實現跨服務
點贊
收藏

51CTO技術棧公眾號

欧美 日韩 国产 成人 在线观看| 欧美日韩亚洲一| 精品人妻一区二区三区日产乱码 | 亚洲日韩欧美视频一区| 欧美在线观看视频网站| 黄色av电影在线观看| 久久资源综合| 色综合久久九月婷婷色综合| 伊人久久大香线蕉成人综合网| 亚洲av永久纯肉无码精品动漫| 久久精品盗摄| 欧美日韩成人免费| 波多野在线播放| 成人午夜三级| 欧美日韩精品久久久| 野外做受又硬又粗又大视频√| 黄色的视频在线免费观看| 国产精品88888| 国产高清视频一区三区| 久久婷婷一区二区| 999成人网| 亚洲免费av电影| 免费啪视频在线观看| 精品国产黄a∨片高清在线| 午夜精品福利在线| av磁力番号网| 欧美高清视频| 久久精品亚洲一区二区三区浴池 | 黄色一级一级片| h片精品在线观看| 亚洲男同1069视频| 色噜噜一区二区| 日本福利片在线| 成人av网站在线观看| 亚洲一区久久久| 91女人18毛片水多国产| 丝袜脚交一区二区| 欧美亚洲成人网| 免费毛片一区二区三区| 欧美~级网站不卡| 久久精品视频网站| 91麻豆精品久久毛片一级| 蜜桃国内精品久久久久软件9| 亚洲成人黄色在线观看| 日本久久久久久久久久| 欧美2区3区4区| 欧美一区二区视频观看视频| 亚洲精品第三页| 福利一区二区免费视频| 欧美性感一类影片在线播放| 无码无遮挡又大又爽又黄的视频| 自拍偷拍亚洲视频| 欧美色欧美亚洲高清在线视频| 日韩小视频在线播放| 999精品网| 激情懂色av一区av二区av| 99热亚洲精品| 狼人综合视频| 欧美视频二区36p| 国产精品少妇在线视频| 欧美日韩视频网站| 色播五月激情综合网| 国产av人人夜夜澡人人爽| 成人日韩在线| 欧美日韩一区二区三区高清| xxx国产在线观看| 欧美黄色a视频| 欧美精品自拍偷拍| 免费看91视频| 欧美亚洲色图校园春色| 亚洲人成在线观看| 久久久久99精品成人| 国产韩国精品一区二区三区| 麻豆成人在线看| 久久免费视频6| 午夜综合激情| 成人黄色在线观看| 亚洲精品久久久狠狠狠爱| 99久久99久久精品国产片果冻 | 精品成人一区二区三区四区| 亚洲少妇一区二区三区| 香蕉精品久久| 在线免费观看羞羞视频一区二区| 日本裸体美女视频| 欧美性久久久| 日本国产精品视频| 一区二区三区免费观看视频| 国产盗摄视频一区二区三区| 久久99国产精品| 91社区在线观看| 一区二区久久久久久| 国产l精品国产亚洲区久久| 欧美日韩国产网站| 日韩精品中文字幕在线一区| 中文字幕一区二区三区人妻不卡| 日韩电影二区| 性欧美亚洲xxxx乳在线观看| 亚洲永久精品视频| 国产成人av在线影院| 欧美日韩在线观看一区| 成人直播在线| 日本道色综合久久| 亚洲天堂小视频| 国内精品久久久久久久久电影网| 欧美成人剧情片在线观看| 亚洲精品午夜国产va久久成人| 久久aⅴ国产欧美74aaa| 久久综合九九| 牛牛精品在线| 欧美日韩国产一区二区三区地区| 亚洲啪av永久无码精品放毛片 | 51xx午夜影福利| 日韩精品专区| 亚洲第一中文字幕在线观看| 性生交大片免费全黄| 国产日韩免费| 国产chinese精品一区二区| 国产69精品久久app免费版| 亚洲高清在线视频| 亚洲欧美日本一区二区三区| 日韩在线麻豆| 91精品国产九九九久久久亚洲| 亚洲熟妇av乱码在线观看| 91色在线porny| 久久这里只有精品8| 亚洲欧美在线人成swag| 一个色综合导航| 五月天激情国产综合婷婷婷| 成人免费av资源| 国产日产欧美一区二区| 国产极品一区| 亚洲午夜久久久影院| 二区视频在线观看| 91影院在线观看| 18禁裸男晨勃露j毛免费观看| 超碰国产精品一区二页| 少妇精69xxtheporn| 天天操天天干天天摸| 91免费国产在线观看| 欧美激情 国产精品| 国产福利一区二区精品秒拍| 九色91av视频| www日本在线| 亚洲一区二区四区蜜桃| 久久久久亚洲av片无码v| 一区二区在线影院| 91网站免费看| 日本在线视频网址| 欧美大片免费久久精品三p| 日日骚一区二区三区| 国产专区综合网| 九一免费在线观看| 中文字幕日韩高清在线| 欧美福利视频在线| 韩国av永久免费| 精品国产福利在线| 18禁裸乳无遮挡啪啪无码免费| 国产亚洲在线| 日韩hmxxxx| 99久久亚洲国产日韩美女| 在线观看欧美视频| 中文字幕一区二区三区波野结| 国产精品热久久久久夜色精品三区| 另类小说色综合| 先锋资源久久| 国产精品.com| 卡通欧美亚洲| 中文字幕久精品免费视频| 亚洲最大成人av| 亚洲人成精品久久久久| 一级少妇精品久久久久久久| 亚洲少妇一区| 亚洲v国产v在线观看| 伊人久久大香线蕉综合影院首页| 欧美成人精品三级在线观看 | 97久久精品人人做人人爽50路| 欧美日韩在线中文| 色偷偷综合网| 国产精品二区在线观看| 巨茎人妖videos另类| 久久韩国免费视频| 韩国av免费在线| 欧美影院一区二区三区| 一区二区视频免费看| 99国产精品99久久久久久| 好男人www社区| 午夜日韩av| 日本日本精品二区免费| 欧美电影院免费观看| 欧美在线视频一二三| 男人和女人做事情在线视频网站免费观看| 日韩视频免费观看高清完整版在线观看 | 国产视频在线一区| 黑人巨大精品欧美一区免费视频 | 国产精品久久久久久亚洲调教| 成人ww免费完整版在线观看| 日韩麻豆第一页| 国产精品视频一二区| 欧美色播在线播放| 欧美日韩激情在线观看| 久久久久久免费网| 久久久久久无码精品人妻一区二区| 香蕉成人久久| 黄网站色视频免费观看| 国产毛片一区二区三区 | 国产精品欧美在线观看| 91色精品视频在线| 芒果视频成人app| 色综合五月天导航| 日本免费视频在线观看| 日韩电影在线观看中文字幕| 成人黄色在线观看视频| 欧美亚一区二区| 日韩视频在线观看一区| 一区二区免费看| 中国毛片直接看| 国产日本欧洲亚洲| 黄色正能量网站| 国产成人在线电影| 午夜精品久久久久久久99热影院| 葵司免费一区二区三区四区五区| 免费高清一区二区三区| 五月开心六月丁香综合色啪| 日韩偷拍一区二区| 西野翔中文久久精品字幕| 国产欧美日韩一区二区三区| 精品99re| 91香蕉嫩草影院入口| 国产福利91精品一区二区| 日本中文字幕不卡免费| 亚洲精品一区二区三区四区| 欧美日韩视频专区在线播放| 秋霞av一区二区三区| 黑人巨大精品欧美一区免费视频 | 国产伦精品一区二区三区视频黑人| 羞羞视频在线观看一区二区| 国产精品黄视频| 91精品影视| 国产成人亚洲综合91精品| 伊人网在线播放| 2019日本中文字幕| 国产精品电影| 97香蕉久久超级碰碰高清版| 国产盗摄在线视频网站| 久久久久久久久久久人体| 污污片在线免费视频| 欧美人成在线视频| 国精一区二区三区| 久久露脸国产精品| 国产深夜视频在线观看| 久久久久久国产精品美女| 女同视频在线观看| 性色av一区二区三区在线观看| av中文字幕在线观看第一页| 国内精品久久久久久| 蜜桃视频在线观看免费视频| 国产91精品视频在线观看| 午夜日韩成人影院| 国产精品亚发布| 亚洲男男av| 国产精品一 二 三| 日韩欧美ww| 日韩中文字幕一区二区| 久久亚洲在线| 国产亚洲精品久久久久久久| 亚洲国产三级| 91淫黄看大片| 国产伦精品一区二区三区免费 | 91日韩精品视频| 国产一区二区久久| 国产一级免费片| 久久久久久97三级| 欧美一区二区三区粗大| 亚洲日本在线a| 国产大片aaa| 在线观看区一区二| 92久久精品一区二区| 精品剧情在线观看| 国际av在线| 美女视频久久黄| 狼人综合视频| 91网站免费看| 亚洲制服一区| 日本高清xxxx| 久久一二三四| 日本特黄在线观看| 2021国产精品久久精品| 色婷婷激情视频| 成人高清免费观看| av手机在线播放| 一区二区三区日韩精品| 久久久黄色大片| 欧美一级搡bbbb搡bbbb| 日韩三级电影网| 久久这里有精品| 日本不卡一二三| 2014亚洲精品| 精品久久久中文字幕| av久久久久久| 欧美aaaaa成人免费观看视频| 91精品国产高清91久久久久久| 国产亚洲欧洲一区高清在线观看| 国产精品免费人成网站酒店| 一本到一区二区三区| 亚洲乱熟女一区二区| 最近2019年好看中文字幕视频| 国产色婷婷在线| 91麻豆桃色免费看| 亚洲国产欧美日韩在线观看第一区| 中文字幕欧美日韩一区二区三区 | 天天干天天曰天天操| 久久久久青草大香线综合精品| 久久久精品91| 欧美精品久久天天躁| 黄色av网站在线免费观看| 国内精品久久久久伊人av| 国产一区二区三区国产精品| 日本精品一区二区三区视频| 国产亚洲激情| 国产精品成人99一区无码| 亚洲另类色综合网站| 中文字幕视频一区二区| 日韩精品免费在线视频| 国产天堂在线播放视频| 91在线视频免费| 日本一二区不卡| 波多野结衣作品集| 91亚洲精华国产精华精华液| 久久久久久久伊人| 日韩欧美成人一区二区| 精品美女在线观看视频在线观看| 国产精品久久久久秋霞鲁丝| 久久99国产成人小视频| 免费成人午夜视频| 99视频热这里只有精品免费| 久久成人在线观看| 日韩欧美亚洲一区二区| aa在线视频| 91亚洲精华国产精华| 久久一区二区三区喷水| 亚洲综合欧美激情| 国产精品视频九色porn| 自拍偷拍福利视频| 最近2019年日本中文免费字幕| 国产69精品久久久久9999人| 亚洲国产激情一区二区三区| 美女免费视频一区二区| 男女全黄做爰文章| 欧美男生操女生| 久久久久久国产精品免费无遮挡 | 久久久久久中文| 超碰在线成人| 欧美精品一区二区三区三州| 99久久99久久久精品齐齐| 日韩三级一区二区| 亚洲性视频网站| 婷婷激情成人| 亚洲精品天堂成人片av在线播放| 国产精品一区2区| 日本熟妇一区二区| 国产网站欧美日韩免费精品在线观看 | 日本人成精品视频在线| 欧美丝袜激情| 中文字幕亚洲影院| 亚洲国产视频直播| 同心难改在线观看| 国产精品白嫩初高中害羞小美女| 日韩精品免费一区二区在线观看| 天堂中文av在线| 亚洲图片欧美一区| 男人的天堂在线视频| 国产精品视频免费在线| 欧美日韩1区| 亚洲精品视频大全| 欧美日韩精品一区二区天天拍小说 | 蜜臀av免费观看| 亚洲精品国产a久久久久久| 丰满熟妇乱又伦| 日韩美女视频免费在线观看| 欧美高清在线| 国产精品成人无码专区| 在线免费观看不卡av| 精品国产白色丝袜高跟鞋| 国产一级特黄a大片99| 视频一区欧美精品| 欧美日韩大片在线观看| 亚洲天堂第二页| 日韩免费高清视频网站| 亚洲精品无码久久久久久| 亚洲欧美一区二区不卡| 飘雪影院手机免费高清版在线观看 | 欧美久久精品一级黑人c片| 欧美日韩破处| 婷婷激情5月天| 狠狠躁夜夜躁人人爽天天天天97| 亚洲成人三级| 九九99玖玖| 国产美女久久久久| 黄色污污网站在线观看| 欧美国产精品日韩|