C#进阶教程(九)

发布时间:2013-09-19 11:33:46来源:阅读(2168)

    现在我要说的是C#中的用户自定义转换(User-Defined Conversions),其中用到了前面说的struct的知识,就是结构呀,忘了吗?好,没忘就好.从我们以下的课程我们可以看到结构的用处(刚才我还在想它有什么用,呵呵).用class声明的是一个类,而用struct声明的可以看作是一个类型,对,就是像C#自带的int,short,long那样的类型了.

      C#中可以允许我们对结构(struct)和类(class)进行转换,所以我们可以在其中定义一些转换.但是,C#规定,所有的转换声明都必须在显示(explicit)和隐示(implicit)中选择一个.比方说,我们用这个语句的时候

      int a=10;
      System.Console.println(a):

      就用到了int的隐示的转换toString.如果是(String)a,就叫做显示.所以,显/隐之差就在于是否表现出来.大家现在肯定还是一头雾水,等到明天我把例子写出来再分析一下就清楚了,要熄灯了,我先走一步了!

      下面给出例子,在这个例子中,一个名为RomanNumeral的类型被声明,然后对他实施了好几种转换.

    000: // UserConversions\conversion.cs
    001: using System;
    002: 
    003: struct RomanNumeral
    004: {
    005: public RomanNumeral(int value) 
    006: { 
    007: this.value = value; 
    008: }
    009: static public implicit operator RomanNumeral(int value) 
    010: {
    011: return new RomanNumeral(value);
    012: }
    013: static public explicit operator int(RomanNumeral roman)
    014: {
    015: return roman.value;
    016: }
    017: static public implicit operator string(RomanNumeral roman)
    018: {
    019: return("Conversion not yet implemented");
    020: }
    021: private int value;
    022: }
    023: 
    024: class Test
    025: {
    026: static public void Main()
    027: {
    028: RomanNumeral numeral;
    029: 
    030: numeral = 10;
    031: 
    032: // 显式地从numeral到int的转换033: Console.WriteLine((int)numeral);
    034: 
    035: // 隐示地转换到string036: Console.WriteLine(numeral);
    037: 
    038: // 显示地转换到int,然后显示地转换到short040: short s = (short)numeral;
    041: 
    042: Console.WriteLine(s);
    043: 
    044: }
    045: }



      这个例子子的输出是:

       10
       Conversion not yet implemented
       10

      注意009和013的operator操作符,它是一个转换操作符.static public explicit operator int(RomanNumeral roman),记住这样的形式,它就代表了一个转换.再看第033行,因为在前面int这个转换被声明成了explicit,即显示地,所以,在使用这个转换时,必须用括号.

      下面再给出一个例子,这个例子声明了两个结构,RomanNumeral和BinaryNumeral,然后在它们之间进行转换.


    000: // UserConversions\structconversion.cs
    001: using System;
    002: 
    003: struct RomanNumeral
    004: {
    005: public RomanNumeral(int value) { this.value = value; }
    006: static public implicit operator RomanNumeral(int value)
    007: {return new RomanNumeral(value);}
    008: static public implicit operator
    009: RomanNumeral(BinaryNumeral binary)
    010: {return new RomanNumeral((int)binary);}
    011: static public explicit operator int(RomanNumeral roman)
    012: {return roman.value;}
    013: static public implicit operator string(RomanNumeral roman) 
    014: {return("Conversion not yet implemented");}
    015: private int value;
    016: }
    017: 
    018: struct BinaryNumeral
    019: {
    020: public BinaryNumeral(int value) {this.value = value;}
    021: 
    022: static public implicit operator BinaryNumeral(int value)
    023: {return new BinaryNumeral(value);}
    024: static public implicit operator string(BinaryNumeral binary)
    025: {return("Conversion not yet implemented");} 
    026: static public explicit operator int(BinaryNumeral binary)
    027: {return(binary.value);}
    028: 
    029: private int value;
    030: }
    031: 
    032: class Test
    033: {
    034: static public void Main()
    035: {
    036: RomanNumeral roman;
    037: roman = 10;
    038: BinaryNumeral binary;
    039: binary = (BinaryNumeral)(int)roman;
    040: roman = binary;
    041: Console.WriteLine((int)binary);
    042: Console.WriteLine(binary);
    043: }
    044: }



      这个例子的输出是:

      10
      Conversion not yet implemented

      注意,第039行并没有直接由RomanNumeral转化成BinaryNumeral,因为没有直接的转换提供.所以先把RomanNumeral转换成int,再转成BinaryNumeral.其余的东西跟上面的例子是一样的(至少我这么认为),如果上面的例子理解了,下面的就好了.

关键字

上一篇: C#进阶教程(十)

下一篇: C#进阶教程(八)