程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> 用好C#中的#region指令 實現良好的代碼組織

用好C#中的#region指令 實現良好的代碼組織

編輯:關於C語言

這篇文章我將不會去介紹如何使用#region指令。因為每個C#開發人員都應該見過和使用過#region指令的。這篇文章將討論如何在代碼中正確的使用它。使用#region就是將一些有關聯的代碼組織在一起,然後折疊起來。這樣你就在一個函數中看不到很長很長的代碼段。例如:

  1. public void DOSomething()  
  2. {    
  3. bool shouldIDOSomething;     
  4. #region Decide if I should do something   
  5. if(needToDOSomething && haventDoneSomethingThisDay)  
  6. shouldIDOSomething = true;   
  7.  else    
  8. {  
  9. // do some other logic to decide and 
  10. set shouldIDOSomething to some value  
  11.   }    
  12. #endregion     
  13. if(shouldIDOSomething)    
  14. {done++;  }} 

當然這段代碼很簡單。在實際項目中,你可能看到上百行甚至更多的代碼在一個#region中。如果把它折疊起來。看起來就會很整潔。是吧?

  1. public void DOSomething()  
  2. {    
  3. bool shouldIDOSomething;     
  4. [Decide if I should do something]     
  5. if(shouldIDOSomething)    
  6. {done++;    
  7. }} 

我們只是把一些代碼和一些變量組合起來放在#region中。如果你在仔細想想,其實我們相當與創建了一個新的函數,只是將這些方法內置到當前方法中。一個函數只做單一的一件事情,這是Clean Code這本書的一個原則。為什麼我們不把它提取為一個方法呢,這樣一來,一個函數就只做一件事情了。

  1. public void DOSomething(){    
  2. if(ShouldIDOSomething())   
  3.  {done++;  }}   
  4. private bool ShouldIDOSomething(){    
  5. if(needToDOSomething && haventDoneSomethingThisDay)  
  6. shouldIDOSomething = true;    
  7. else   
  8.  {  
  9. // do some other logic to decide   
  10. and set shouldIDOSomething to some value  }} 

這樣看起來就清楚很多,因為我們降低了之前的DOSomething函數的復雜度。兩個函數可以分開測試,確保沒有邏輯錯誤。
小段總結1:  #region 不適合在大方法中使用,當你在一個方法中使用#region 的時候,停下來想想你剛剛寫了什麼代碼?大多數時候,你可以將這些代碼段獨立成一個函數。

看看下面這段非常漂亮的代碼:

  1. #region Get Customer   
  2. public void GetCustomer(){    
  3. // code to get the customer}   
  4. #endregion   
  5. #region Save Customer   
  6. public void SaveCustomer(){    
  7. // code to save the customer}   
  8. #endregion 

將它折疊之後,變成下面這樣:

  1. [Get Customer] [Save Customer] 

這樣做很容易閱讀嗎?這樣做的目的是什麼,我不明白?代碼折疊就會變得更好?我覺得這樣做只會讓代碼更難以閱讀,因為你每次要看region中的代碼,你都要展開一次。

小段總結2:不要因為你能,你就使用#region 。

再看下面這個例子

  1. public class PriceCalculator{    
  2. public decimal CalculatePrice()    
  3. {decimal price = 100m;decimal discount = CalculateDiscount();  
  4. return price * (1m - discount));   
  5.  }     
  6. #region Discount Calculation     
  7. private void CalculateDiscount()    
  8. {decimal discount = 0m;   
  9. if(CanApplyDiscount())    
  10. discount = 0.05m;   
  11. return discount;   
  12.  }     
  13. private void CanApplyDiscount()  {  
  14. // some logic, other method calls  }     
  15. // some other discount calculation methods  ...     
  16. #endregion} 

如果你將這個例子和本文中的第一個例子做下比較,你可能會看到它們的共同點。他們是相同的,不過一個是在類中,一個是在函數中,層級不同而已。這裡在提一個原則:單一職責原則,一個類應該只有一個職責。看上面的類,你可以很容易看出它有兩個職責:價格計算和折扣計算。折扣計算的方法被放到一個#region中。同樣,可以將它們提取出來做為一個新類。

小段總結3:可以將一組相關的函數提取到一個職責單一的新類中。

那我們到底怎麼使用 #region 呢。將東西用它來分組,它是非常有用的。在我寫的類中或多或少有幾個regions,用來對類中不同的結構進行分組。比如: fields, propertIEs, methods, events, types等。如果你打開我寫的類文件,你會看到結構如下:

  1. public class SomeClass{  
  2. [Events]  
  3. [FIElds]  
  4. [PropertIEs]   
  5. [Methods]} 

總的來說:我將region看成能控制閱讀源代碼的復雜度的一種方式。因為你可以將一些相關的代碼放在一個區域(region)裡面。但是,這不是隨便就創建的新的方法或者新類的借口。其實Region並不能消除復雜度,它只是在你閱讀代碼的時候,隱藏了部分代碼。你必須通過寫出小巧,清晰,重點突出的方法和類,才能控制代碼的復雜度。當你做到這些的時候,你甚至會發現region是不必要的。

原文標題:如何正確地使用#region指令

鏈接:http://www.cnblogs.com/zhuqil/archive/2010/09/07/about-region-preprocessor-directive.Html

【編輯推薦】

  1. C#模式窗體中的按鈕操作
  2. C#模式窗體操作詳解
  3. C#窗體繼承原理以及實現淺析
  4. C#窗體關閉事件的重載實現淺析
  5. C#窗體位置與大小設置詳解
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved