用C#编程的提出

1.如果可能尽量拔取接口来编程  
    
  .NET框架包蕴类和接口,在编写程序的时候,你恐怕了解正在用.NET的哪个类。但是,在那种情景下假使你用.NET支持的接口而不是它的类来编程时,代码会变得更为稳定、可用性会更高。

请分析上面的代码:  
      

1   private void LoadList (object [] items, ListBox l)  
2   {  
3    for (int i = 0; i < items.Length;i++)  
4     l.Items.Add (items[i].ToString ());  
5   } 

    

  那几个函数从一个可为任何对象的数组中加载ListBox,那段代码被限定为只可以利用数组。假想过些时候你意识这几个对象存在数据库中,或其余集合中。那么你要求修改程序来拔取分化的聚合类型。即便你用ICollection接口来写那段程序,你就无须修改那段程序了,对于其他已毕ICollection接口的门类它都能很好的干活:  
    

1   private void LoadList (ICollection items,ListBox l)  
2   {  
3     foreach (object o in items)  
4     l.Items.Add (o.ToString ());  
5   }  

    

  ICollection被数组和兼具System.Collection中的集合完毕。其余,多维数组也支撑ICollection接口。假诺那还不够的话,数据库.NET类同样支撑ICollection接口。用接口写的那几个函数不用需改就可以才许多中状态下利用。  
    

2. 用到性能代替本来数据  
    
  因为属性已经成为语言本身的因素,所以评释数据元素时它的成效域等级没有要求大于private。因为代码本身会把性能看成数据元素,你并没有错过利用简易数据类型的便利性 。相反它会使你的代码尤其灵敏功用进一步强劲。属性使您的数据元素封装性更好。属性可以让您利用lazy evaluation来回到数据。lazy evaluation的情趣是当用户请求时才统计它的值,而不是一贯保留着它。  

  最终,属性可以是virtual也足以是abstract。你也足以在接口中定义属性。  
C#,    
  那里还有有限支撑方面的元素应当注意:即便操作两者的法子是一样的,但是你把一个多少元素变为属性,那么原来客户端的主次便不可以访问服务端的新本子程序了。实际上对于在Web service中您想完成连串化的值你可以把它们成为属性来利用:  
      

 1 private int TheMonth = 0;  
 2     
 3   [XmlAttribute ("Month")]  
 4   public int Month  
 5   {  
 6    get {  
 7     return TheMonth;  
 8    }  
 9    set {  
10     TheMonth = value;  
11    }  
12   } 

 

    
  简单通过性能就能够使你的保有数据元素私有化。  
    

3. 在Producer/Consumer 的Idiom中使用Delegate  
    
  当您生成一个兑现producer idiom类的时候,使用deletate来布告consumer。那种艺术相对于用接口越发灵敏。Delegate是多点传送的,所以不要加额外的代码你就怎么协助多用户。相对于用接口那样做可使类之间的耦合性下跌。  
    http://www.cnblogs.com/roucheng
  上面的类处理键盘输入并把它传给所有的registered listeners:  
    
  public class KeyboardProcessor  
  {  
  private OnGetLine theFunc = null;  
    
  public OnGetLine OnGetLineCallback {  
   get {  
    return theFunc;  
   }  
   set {  
    theFunc = value;  
   }  
  }  
    
  public void Run (){  
  // Read input.  
  // If there is any listeners, publish:  
  string s;  
  do {  
   s = Console.ReadLine ();  
   if (s.Length == 0)  
    break;  
   if (theFunc != null){  
    System.Delegate [] funcs =theFunc.GetInvocationList();  
    foreach (OnGetLine f in funcs) {  
     try {  
      f (s);  
     } catch (Exception e) {  
      Console.WriteLine  
      (“Caught Exception: {0}”, e.Message);  
     }  
    }  
   }  
  } while (true);  
  }  
    
  任何数据的listeners都可登记到producer,它们所要做的只是提供一个特定的函数:deletate。  
    

4. 留意开头化顺序  
    
  C#中对此一些变量申明加入了initializer的定义。它们在构造函数从前被执行,实际上变量在基类的构造函数执行前以前被开端化。  
    
  所以,在伊始化变量的时候绝不用基类中的数据,因为它们还并未被社团。 

相关文章