使代碼簡潔的 5 條忠告

寫代碼是一種藝術。使用Delphi,任何人都可以輕而易舉地開發出某種軟件、完成某些任務。而完美的代碼則只有真正的高手才能寫出。除了正確的縮進、大小寫、命名規則之外,請時刻牢記愛因斯坦的名言--簡單就是美。下面將談及的五個代碼問題,可能是初學者、甚至一些老鳥都會犯的錯誤。


忠告一

布爾型變量的賦值操作應該是直接的。例如,在一個if/then/else語句中,if子句將布爾型變量賦值爲True,而else子句將其賦爲False。下面這段代碼的寫法是不好的:

if If_Love_Delphi then
  Result:=True
else
  Result:=False;

而這樣寫就比較好:

Result:= If_Love_Delphi;


忠告二

避免使用嵌套的if/then/if語句,而用and來代替。下面這段代碼太羅嗦:

if If_Love_Delphi then
  if If_Love_Linux then
TryKylix(Now);

應該這樣寫:

if If_Love_Delphi and If_Love_Linux then
  TryKylix(Now);

不用擔心後面的判斷語句會超前執行。Project|Options|Compiler|Syntax Options|Complete Boolean eval選項通常是關閉的(除非你選定這個項),這保證了執行順序不會顛倒。

綜合前兩個忠告,假如你有一段這樣的代碼:

if If_Love_Delphi then
  if If_Love_Linux then
Result:=True;

就可以把它改成:

Result:= If_Love_Delphi and If_Love_Linux;

簡單而言,假如結果取決於一個條件判斷,那麼,Result:=True或者Result:=False這樣的語句就是多此一舉。在初始化布爾型變量的時候,可以給它們賦值。不過根本用不着把一個布爾型變量初始化爲False--Delphi在創建這個變量的時候就已經把它賦職位False了。相似的情況還有:

對象的布爾型屬性(Boolean),自動被初始化爲False (0);
整型變量(Integer),自動被初始化爲 0;
字符串(String),自動被初始化爲空字符串。


忠告三

判斷布爾型變量的值時,無需用"=True"或者"=False"這樣的語句。下面的寫法不好:

if (If_Love_Delphi=True) and
  (If_Love_Linux=False) then
    DoNotTryLinux;

對於函數的返回值或者一個屬性是布爾型的情況,應該這樣寫:

if If_Love_Delphi and
  not If_Love_Linux then
DoNotTryLinux;


忠告四

儘量不要用"+"操作符進行字符串合併。這樣做效率太低了。下面的例子不好:

ShowMessage('在下身高'+IntToStr(iHeight)+'米,體重'+IntToStr(iWeight)+'公斤。');

這樣寫會較好:

ShowMessage(Format('在下身高%d,體重%d。', [iHeight,iWeight]));


忠告五

儘量多用with語句。它不僅效率高,而且使代碼更加易讀。比如,這段代碼:

if Sender if TEdit then
  if (TEdit(Sender).Text=') or
(TEdit(Sender).Text[TEdit(Sender).SelStart]=') or
  (TEdit(Sender).SelLength=
Length(TEdit(Sender).Text))
and (Key in ['a'..'z']) then
Key:=UpperCase(Key);

就不如這樣的代碼來得簡潔易讀:

if Sender is TEdit then
  with Sender as TEdit do
if (Text=') or
   (Text[SelStart]=') or
   (SelLength=Length(Text)) and
   (Key in ['a'..'z'] then
  Key:=UpCase(Key);
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章