亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python-typing: 類型標注與支持 Any類型詳解

瀏覽:2日期:2022-06-20 10:02:41

Any docs

Any 是一種特殊的類型。

靜態類型檢查器將所有類型視為與 Any 兼容,反之亦然, Any 也與所有類型相兼容。

這意味著可對類型為 Any 的值執行任何操作或方法調用,并將其賦值給任何變量:

from typing import Anya = None # type: Anya = [] # OKa = 2 # OKs = ’’ # type: strs = a # OKdef foo(item: Any) -> int: # Typechecks; ’item’ could be any type, # and that type might have a ’bar’ method item.bar() ...

需要注意的是,將 Any 類型的值賦值給另一個更具體的類型時,Python不會執行類型檢查。例如,當把 a 賦值給 s 時,即使 s 被聲明為 str 類型,在運行時接收到的是 int 值,靜態類型檢查器也不會報錯。

此外,所有返回值無類型或形參無類型的函數將隱式地默認使用 Any 類型:

def legacy_parser(text): ... return data# A static type checker will treat the above# as having the same signature as:def legacy_parser(text: Any) -> Any: ... return data

當需要混用動態類型和靜態類型的代碼時,上述行為可以讓 Any 被用作 應急出口 。

Any 和 object 的行為對比。

與 Any 相似,所有的類型都是 object 的子類型。然而不同于 Any,反之并不成立: object 不是 其他所有類型的子類型。

這意味著當一個值的類型是 object 的時候,類型檢查器會拒絕對它的幾乎所有的操作。把它賦值給一個指定了類型的變量(或者當作返回值)是一個類型錯誤。

比如說:

def hash_a(item: object) -> int: # Fails; an object does not have a ’magic’ method. item.magic() ...def hash_b(item: Any) -> int: # Typechecks item.magic() ...# Typechecks, since ints and strs are subclasses of objecthash_a(42)hash_a('foo')# Typechecks, since Any is compatible with all typeshash_b(42)hash_b('foo')

使用 object 示意一個值可以類型安全地兼容任何類型。使用 Any 示意一個值地類型是動態定義的。

補充:python3.5 typing — 類型標注支持

函數接受并返回一個字符串,注釋像下面這樣:

def greeting(name: str) -> str: return ’Hello’ + name

在函數 greeting 中,參數 name 預期是 str 類型,并且返回 str 類型。子類型允許作為參數。

1.1. 類型別名

型別名通過將類型分配給別名來定義。在這個例子中, Vector 和 List[float] 將被視為可互換的同義詞:

from typing import ListVector = List[float]def scale(scalar: float, vector: Vector) -> Vector: return [scalar * num for num in vector]# typechecks; a list of floats qualifies as a Vector.new_vector = scale(2.0, [1.0, -4.2, 5.4])類型別名可用于簡化復雜類型簽名。

例如:

from typing import Dict, Tuple, ListConnectionOptions = Dict[str, str]Address = Tuple[str, int]Server = Tuple[Address, ConnectionOptions]def broadcast_message(message: str, servers: List[Server]) -> None: ...# The static type checker will treat the previous type signature as# being exactly equivalent to this one.def broadcast_message(message: str,servers: List[Tuple[Tuple[str, int], Dict[str, str]]]) -> None: ...

請注意,None 作為類型提示是一種特殊情況,并且由 type(None) 取代。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产日韩久久久精品影院首页 | 色综合久久丁香婷婷 | 青草视频免费在线观看 | 国产小视频在线观看www | 欧美大片在线观看成人 | 欧美成人一区二区三区在线电影 | 久热99这里只有精品视频6 | 九一在线完整视频免费观看 | 成人一级黄色片 | 国产成人福利在线视老湿机 | 亚洲20p| 亚洲国产婷婷综合在线精品 | 国产最新进精品视频 | 日本一区二区免费在线 | 午夜精品久久久久久久 | 国产精品第一页在线观看 | 久久色视频 | 欧美洲精品亚洲精品中文字幕 | 国产一级片免费 | 色播亚洲视频在线观看 | 欧美日韩一二区 | 99久久999久久久综合精品涩 | 男女性黄色 | 中文字幕第一页在线视频 | 中文字幕一区婷婷久久 | 国产在线一区二区三区 | 免费看黄在线观看 | 国产在线a | 国产性生大片免费观看性 | 国产精品你懂的在线播放调教 | 久久国产精品久久久 | 亚洲香蕉视频 | 久久国产精品99久久久久久牛牛 | 国产高清不卡码一区二区三区 | 国产精品入口麻豆 | 日韩高清一区二区三区不卡 | 啪啪综合网 | 国产精品第一 | 国产理论视频在线观看 | 日韩高清在线高清免费 | 国产成人一区二区三区高清 |