前言
Quora 問答社區(qū)的一個(gè)開發(fā)者投票統(tǒng)計(jì),程序員最大的難題是:如何命名(例如:給變量,類,函數(shù)等等),光是如何命名一項(xiàng)的選票幾乎是其它八項(xiàng)的投票結(jié)果的總和。如何給變量命名,如何讓它變得有意義成了程序員不可逾越的難題,這篇文章參考了 Clean Code ,提供7條命名建議,希望能在取名字的過程中給你帶來一些幫助。
以下都是基于Python3.7語法
1、使用有意義而且可讀的變量名
差
ymdstr = datetime.date.today().strftime("%y-%m-%d")
鬼知道 ymd 是什么?
好
current_date: str = datetime.date.today().strftime("%y-%m-%d")
看到 current_date,一眼就懂。
2、同類型的變量使用相同的詞匯
差 這三個(gè)函數(shù)都是和用戶相關(guān)的信息,卻使用了三個(gè)名字
get_user_info() get_client_data() get_customer_record()
好 如果實(shí)體相同,你應(yīng)該統(tǒng)一名字
get_user_info() get_user_data() get_user_record()
極好 因?yàn)?Python 是一門面向?qū)ο蟮恼Z言,用一個(gè)類來實(shí)現(xiàn)更加合理,分別用實(shí)例屬性、property 方法和實(shí)例方法來表示。
class User: info : str @property def data(self) -> dict: # ... def get_record(self) -> Union[Record, None]: # ...
3、使用可搜索的名字
大部分時(shí)間你都是在讀代碼而不是寫代碼,所以我們寫的代碼可讀且可被搜索尤為重要,一個(gè)沒有名字的變量無法幫助我們理解程序,也傷害了讀者,記住:確保可搜索。
差
time.sleep(86400);
What the fuck, 上帝也不知道86400是個(gè)什么概念
好
# 在全局命名空間聲明變量,一天有多少秒 SECONDS_IN_A_DAY = 60 * 60 * 24 time.sleep(SECONDS_IN_A_DAY)
清晰多了。
4、使用可自我描述的變量
差
address = 'One Infinite Loop, Cupertino 95014' city_zip_code_regex = r'^[^,\\]+[,\\\s]+(.+?)\s*(\d{5})?$' matches = re.match(city_zip_code_regex, address) save_city_zip_code(matches[1], matches[2])
matches[1] 沒有自我解釋自己是誰的作用
一般
address = 'One Infinite Loop, Cupertino 95014' city_zip_code_regex = r'^[^,\\]+[,\\\s]+(.+?)\s*(\d{5})?$' matches = re.match(city_zip_code_regex, address) city, zip_code = matches.groups() save_city_zip_code(city, zip_code)
你應(yīng)該看懂了, matches.groups() 自動(dòng)解包成兩個(gè)變量,分別是 city,zip_code
好
address = 'One Infinite Loop, Cupertino 95014' city_zip_code_regex = r'^[^,\\]+[,\\\s]+(?P.+?)\s*(?P \d{5})?$' matches = re.match(city_zip_code_regex, address) save_city_zip_code(matches['city'], matches['zip_code'])
5、 不要強(qiáng)迫讀者猜測變量的意義,明了勝于晦澀
差
seq = ('Austin', 'New York', 'San Francisco') for item in seq: do_stuff() do_some_other_stuff() # ... # Wait, what's `item` for again? dispatch(item)
seq 是什么?序列?什么序列呢?沒人知道,只能繼續(xù)往下看才知道。
好
locations = ('Austin', 'New York', 'San Francisco') for location in locations: do_stuff() do_some_other_stuff() # ... dispatch(location)
用 locations 表示,一看就知道這是幾個(gè)地區(qū)組成的元組
6、不要添加無謂的上下文
如果你的類名已經(jīng)可以告訴了你什么,就不要在重復(fù)對變量名進(jìn)行描述
差
class Car: car_make: str car_model: str car_color: str
感覺畫蛇添足,如無必要,勿增實(shí)體。
好
class Car: make: str model: str color: str
7、使用默認(rèn)參數(shù)代替短路運(yùn)算和條件運(yùn)算
差
def create_micro_brewery(name): name = "Hipster Brew Co." if name is None else name slug = hashlib.sha1(name.encode()).hexdigest() # etc.
好
def create_micro_brewery(name: str = "Hipster Brew Co."): slug = hashlib.sha1(name.encode()).hexdigest() # etc.
這個(gè)應(yīng)該能理解吧,既然函數(shù)里面需要對沒有參數(shù)的變量做處理,為啥不在定義的時(shí)候指定它呢?
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
