你必须知道的.NET.doc


文档分类:IT计算机 | 页数:约247页 举报非法文档有奖
1/247
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/247
文档列表 文档介绍
该【你必须知道的.NET 】是由【儒林】上传分享,文档一共【247】页,该文档可以免费在线阅读,需要了解更多关于【你必须知道的.NET 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。
1第一回:恩怨情仇:is和as
本文将介绍以下内容:
•类型转换
•is/as操作符小议 
1. 引言 
,对于程序设计者来说,完全把握系统数据的类型安全,经常是力不从心的问题。现在,这一切已经在微软大牛们的设计框架中为你解决了。,,因此我们可以很容易的获得对象的准确类型,方法是:GetType()方法。,应该考虑的地方有那些呢?

类型转换包括显示转换和隐式转换,:
任何类型都可以安全的转换为其基类类型,可以由隐式转换来完成;
任何类型转换为其派生类型时,必须进行显示转换,转换的规则是:(类型名)对象名;
使用GetType可以取得任何对象的精确类型;
基本类型可以使用Covert类实现类型转换;
除了string以外的其他类型都有Parse方法,用于将字符串类型转换为对应的基本类型;
值类型和引用类型的转换机制称为装箱(boxing)和拆箱(unboxing)。

浅谈了类型转换的几个普遍关注的方面,该将主要精力放在is、as操作符的恩怨情仇上了。类型转换将是个较大的话题,留于适当的时机讨论。
is/as操作符,是C#中用于类型转换的,提供了对类型兼容性的判断,从而使得类型转换控制在安全的范畴,提供了灵活的类型转换控制。
is的规则如下:
检查对象类型的兼容性,并返回结果,true或者false;
不会抛出异常;
如果对象为null,则返回值永远为false。
其典型用法为:
 1object o = new object();
 2
 3class A
 4
 5{
 6
 7}
 8
纵上比较,is/as操作符,提供了更加灵活的类型转型方式,但是as操作符在执行效率上更胜一筹,我们在实际的编程中应该体会其异同,酌情量才。 
第二回:对抽象编程:接口和抽象类
本文将介绍以下内容:
•面向对象思想:多态
•接口
•抽象类
 1. 引言
在我之前的一篇post《抽象类和接口的谁是谁非》中,和同事管伟的讨论,得到很多朋友的关注,因为是不成体系的论道,所以给大家了解造成不便,同时关于这个主题的系统性理论,我认为也有必要做以总结,因此才有了本篇的新鲜出炉。同时,我将把上贴中的问题顺便也在此做以交代。

什么是接口?
接口是包含一组虚方法的抽象类型,其中每一种方法都有其名称、参数和返回值。接口方法不能包含任何实现,CLR允许接口可以包含事件、属性、索引器、静态方法、静态字段、静态构造函数以及常数。但是注意:C#中不能包含任何静态成员。一个类可以实现多个接口,当一个类继承某个接口时,它不仅要实现该接口定义的所有方法,还要实现该接口从其他接口中继承的所有方法。
定义方法为:
 public interface 
 {
  int CompareTo(object o);
 }
 public class TestCls: IComparable
 {
  public TestCls()
  {
  } 
  private int _value;
  public int Value
  {
get { return _value; }
set { _value = value; }
  } 
  public int CompareTo(object o)
  {
//使用as模式进行转型判断
TestCls aCls = o as TestCls;
if (aCls != null)
{
//实现抽象方法
return ();
}
  }
 }
什么是抽象类?
抽象类提供多个派生类共享基类的公共定义,它既可以提供抽象方法,也可以提供非抽象方法。抽象类不能实例化,必须通过继承由派生类实现其抽象方法,因此对抽象类不能使用new关键字,也不能被密封。如果派生类没有实现所有的抽象方法,则该派生类也必须声明为抽象类。另外,实现抽象方法由overriding方法来实现。
定义方法为:
/// <summary>
/// 定义抽象类
/// </summary>
abstract public class Animal
{
 //定义静态字段
 protected int _id; 
 //定义属性
 public abstract int Id
 {
  get;
  set;
 } 
 //定义方法
 public abstract void Eat(); 
 //定义索引器
 public string this[int i]
 {
  get;
  set;
 } 

/// <summary>
/// 实现抽象类
/// </summary>
public class Dog: Animal
{
 public override int Id
 {
  get {return _id;}
  set {_id = value;}
 } 
 public override void Eat()
 {
  ("Dog Eats.")
 }



都不能被直接实例化,都可以通过继承实现其抽象方法。
都是面向抽象编程的技术基础,实现了诸多的设计模式。

接口支持多继承;抽象类不能实现多继承。
接口只能定义抽象规则;抽象类既可以定义规则,还可能提供已实现的成员。
接口是一组行为规范;抽象类是一个不完全的类,着重族的概念。
接口可以用于支持回调;抽象类不能实现回调,因为继承不支持。
接口只包含方法、属性、索引器、事件的签名,但不能定义字段和包含实现的方法;抽象类可以定义字段、属性、包含有实现的方法。 
接口可以作用于值类型和引用类型;抽象类只能作用于引用类型。例如,Struct就可以继承接口,而不能继承类。
 通过相同与不同的比较,我们只能说接口和抽象类,各有所长,但无优略。在实际的编程实践中,我们要视具体情况来酌情量才,但是以下的经验和积累,或许能给大家一些启示,除了我的一些积累之外,很多都来源于经典,我相信经得起考验。所以在规则与场合中,我们学习这些经典,最重要的是学以致用,当然我将以一家之言博大家之笑,看官请继续。

请记住,面向对象思想的一个最重要的原则就是:面向接口编程。
借助接口和抽象类,23个设计模式中的很多思想被巧妙的实现了,我认为其精髓简单说来就是:面向抽象编程。
抽象类应主要用于关系密切的对象,而接口最适合为不相关的类提供通用功能。
接口着重于CAN-DO关系类型,而抽象类则偏重于IS-A式的关系;
接口多定义对象的行为;抽象类多定义对象的属性; 
接口定义可以使用public、protected、internal 和private修饰符,但是几乎所有的接口都定义为public,原因就不必多说了。
“接口不变”,是应该考虑的重要因素。所以,在由接口增加扩展时,应该增加新的接口,而不能更改现有接口。
尽量将接口设计成功能单一的功能块,,IDisposable、IDisposable、IComparable、IEquatable、IEnumerable等都只包含一个公共方法。
接口名称前面的大写字母“I”是一个约定,正如字段名以下划线开头一样,请坚持这些原则。
在接口中,所有的方法都默认为public。 
如果预计会出现版本问题,可以创建“抽象类”。例如,创建了狗(Dog)、鸡(Chicken)和鸭(Duck),那么应该考虑抽象出动物(Animal)来应对以后可能出现风马牛的事情。而向接口中添加新成员则会强制要求修改所有派生类,并重新编译,所以版本式的问题最好以抽象类来实现。
从抽象类派生的非抽象类必须包括继承的所有抽象方法和抽象访问器的实实现。
对抽象类不能使用new关键字,也不能被密封,原因是抽象类不能被实例化。
在抽象方法声明中不能使用static或virtual修饰符。
以上的规则,我就厚颜无耻的暂定为T14条吧,写的这么累,就当一时的奖赏吧。大家也可以互通有无,我将及时修订。


.NETFramework是学习的最好资源,,关于接口和抽象类在FCL中的使用,我有以下的建议:
FCL对集合类使用了基于接口的设计,;
FCL对数据流相关类使用了基于抽象类的设计,。
 别样小菜
下面的实例,因为是我的理解,因此给经典打上“相对”的记号,至于什么时候晋升为“绝对”,,是否能够一如既往的如此执着,因此我将把相对重构到绝对为止(呵呵)。本示例没有阐述抽象类和接口在设计模式中的应用,因为那将是另一篇有讨论价值的文本,本文着眼与概念和原则的把握,但是真正的应用来自于具体的需求规范。
设计结构如图所示:
../../../../../DocumentsandSettings/Anytao/ApplicationData/WindowsLiveWriter/PostSupportingFiles/3f7def05-957f-4c3d-9d7b-adedc96255ed/classView1%5b1%
 
1. 定义抽象类
 public abstract class Animal
 {
  protected string _name;
  //声明抽象属性
  public abstract string Name
  {
get;
  }
  //声明抽象方法
  public abstract void Show();
  //实现一般方法
  public void MakeVoice()
  {
("All animals can make voice!");
  }
 }
2. 定义接口
 public interface IAction
 {
  //定义公共方法标签
  void Move();
 }

 public class Duck : Animal, IAction
 {
  public Duck(string name)
  {
_name = name;
  }
  //重载抽象方法
  public override void Show()
  {
(_name + " is showing for you.");
  }
  //重载抽象属性
  public override string Name
  {
get { return _name;}
  }
  //实现接口方法
  public void Move()

你必须知道的.NET 来自淘豆网m.daumloan.com转载请标明出处.

相关文档 更多>>
非法内容举报中心
文档信息
  • 页数247
  • 收藏数0 收藏
  • 顶次数0
  • 上传人儒林
  • 文件大小3.89 MB
  • 时间2022-10-05