if (true){
return true;
} else {
return false;
}
}  每次當我深入某個開源項目,看到大概 " /> 国产亚洲精品线观看77,亚洲精品高清国产一线久久97,欧美激情 亚洲

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

只要一個返回語句

  本文是從 A return to Good Code 這篇文章翻譯而來。

  別再這樣寫了:

public boolean foo(){
 if (true){
   return true;  
 } else { 
 return false;  
 }
}

  每次當我深入某個開源項目,看到大概是某個專家寫的、并被有經驗的專業人士審查過的這樣的代碼,我都會驚訝不已,竟然沒有人去阻止這個開發者在這個方法里胡亂的放置返回語句。

  請告訴我,把代碼寫成下面的樣子很難嗎?

public boolean foo(){ 
 boolean flag = true;  
 if (true){ 
   flag=true;
 } 
 else {
   flag=false;
 }
 return flag;
}

  這是Java基本常識。實際上,這不僅是Java基本常識,這是小學水平的Java知識。如果你的方法返回一個值,你應該在方法的開始處把它聲明做一個變量。然后再去做一些賦予這個變量正確意義的操作。然后,在你的最后一行,把這個變量返回給調用程序。這樣做不僅僅是為寫出好的代碼,這是一種有教養的表現。

  你是否曾試圖修改過一些在方法里到處都是返回語句的程序代碼?無從下手。事實上,去維護這樣的代碼,你第一要做的是重新組織它的結構,讓它里面不再有一大堆的返回語句。這樣才能把事情做好。沒有任何一個方法是不可以寫成只在末尾處有一個的、單一的、易于找到的返回語句的形式的。

  的確,爛程序員總有一萬個理由來說明他們為什么編寫出這樣糟糕的程序代碼。“我只是為了避免在返回時一堆的多余的條件判斷語句。”那好,首先,我告訴你,計算機中執行一些條件判斷語句時是該死的快,你用短路一個方法來節省CPU的一兩個指令操作不是顯的太荒誕了嗎。此外,如果這些所謂多余的條件判斷語句最終沒有派上用場的話,這是否是一個有用的信號來說明你的“多余”的代碼可能需要重寫,也許可以把它們重構成另外一個方法,讓它們顯的不多余?

  關鍵要說的是,沒有任何理由可以為寫糟糕的代碼或當懶惰的程序員做托辭,特別是當寫出好的代碼并不是那么困難的情況下。不要在寫出里面有成百上千個返回語句的方法了。Java里的方法只可以返回一個值,相應的,一個方法應該有且只有一個返回語句。

it知識庫只要一個返回語句,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 五月激情久久 | 中文字幕一区二区三区精彩视频 | 五月综合激情 | 免费一区二区三区免费视频 | 国产精品亚洲第一区二区三区 | 在线婷婷 | 日韩视频91 | 在线观看污污网站 | 黄色美女网站免费看 | 午夜在线播放视频 | 国产第一页久久亚洲欧美国产 | 久久综合中文字幕一区二区三区 | 四虎影视在线影院4hutv | 91久久青青青国产免费 | 福利在线观看 | 国产1级毛片 | 秋霞伊人| 国产情侣真实露脸在线最新 | 黄页网址大全免费观看美女 | 91精品一区二区三区在线 | 青春草久久| 国语自产免费精品视频一区二区 | 成人精品国产亚洲 | 高清不卡免费一区二区三区 | 国色天香一区三区四区小说 | 国产亚洲精品国产福利在线观看 | 亚洲天堂一区二区在线观看 | 精品91视频 | 一区二区免费视频 | 新版天堂资源中文8在线 | 亚州综合激情另类久久久 | 伊人久久综在合线亚洲91 | 色婷婷在线视频 | 色女人天堂 | 色中文在线| 国内精品福利在线视频 | 五月婷网| 精品日本亚洲一区二区三区 | 好吊色在线视频 | 精品久久久中文字幕 | 四虎网站最新 |