《CLR Via C# 第3版》笔记之(八) - 类型的转换构造器和方法

简介:

主要内容

  • 类型的转换构造器
  • 显式/隐式的转换操作符

1. 类型的转换构造器

类型转换构造器是指 通过一种类型(比如Type1)的实例来构造另一种类型(比如Type2)的实例。

一般用于:

1) Type1和Type2之间没有继承关系,但是仍然希望从Type1转换到Type2

2) Type1和Type2是完全不同的两种类型

使用方法如下:

using System;

namespace cnblog_bowen
{
    public class CLRviaCSharp_8
    {
        static void Main(string[] args)
        {
            Type1 t1 = new Type1(10);
            t1.Show();

            // 通过Type1 来构造 Type2
            Type2 t2 = new Type2(t1);
            t2.Show();
            Console.ReadKey(true);
        }
    }

    public class Type1
    {
        private Int32 type1_n;
        public int Type1_n { get { return type1_n; } }

        public Type1(Int32 n)
        {
            type1_n = n;
        }

        public void Show()
        {
            Console.WriteLine("type1_n = " + type1_n.ToString());
        }
    }

    public class Type2
    {
        private Int32 type2_n;

        // 类型转换构造器,根据Type1来构造Type2
        public Type2(Type1 t1)
        {
            type2_n = t1.Type1_n + 10;
        }

        public void Show()
        {
            Console.WriteLine("type2_n = " + type2_n.ToString());
        }
    }
}

显示结果如下:

image

2. 显式/隐式的转换操作符

我们可以看出 通过构造器来完成类型的转换并不是很灵活。

其实C#中还提供了显示和隐式的转换方法。

隐式转换的代码如下:

using System;

namespace cnblog_bowen
{
    public class CLRviaCSharp_8
    {
        static void Main(string[] args)
        {
            Type1 t1 = new Type1(10);
            t1.Show();

            // 通过隐式转换将Type1转为Type2
            Type2 t2 = t1;
            t2.Show();
            Console.ReadKey(true);
        }
    }

    public class Type1
    {
        private Int32 type1_n;
        public int Type1_n { get { return type1_n; } }

        public Type1(Int32 n)
        {
            type1_n = n;
        }

        public void Show()
        {
            Console.WriteLine("type1_n = " + type1_n.ToString());
        }
    }

    public class Type2
    {
        private Int32 type2_n;

        // 类型转换构造器,根据Type1来构造Type2
        public Type2(Type1 t1)
        {
            type2_n = t1.Type1_n + 10;
        }

        // implicit关键字表示是隐式转换
        public static implicit operator Type2(Type1 t1)
        {
            return new Type2(t1);
        }

        public void Show()
        {
            Console.WriteLine("type2_n = " + type2_n.ToString());
        }
    }
}

显式转换的代码如下:

using System;

namespace cnblog_bowen
{
    public class CLRviaCSharp_8
    {
        static void Main(string[] args)
        {
            Type1 t1 = new Type1(10);
            t1.Show();

            // 通过显式转换将Type1转为Type2
            Type2 t2 = (Type2)t1;
            t2.Show();
            Console.ReadKey(true);
        }
    }

    public class Type1
    {
        private Int32 type1_n;
        public int Type1_n { get { return type1_n; } }

        public Type1(Int32 n)
        {
            type1_n = n;
        }

        public void Show()
        {
            Console.WriteLine("type1_n = " + type1_n.ToString());
        }
    }

    public class Type2
    {
        private Int32 type2_n;

        // 类型转换构造器,根据Type1来构造Type2
        public Type2(Type1 t1)
        {
            type2_n = t1.Type1_n + 10;
        }

        // explicit关键字表示是显式转换
        public static explicit operator Type2(Type1 t1)
        {
            return new Type2(t1);
        }

        public void Show()
        {
            Console.WriteLine("type2_n = " + type2_n.ToString());
        }
    }
}

通过显式/隐式转换操作符来进行类型转换时需要注意两点:

1)显式/隐式转换函数必须是public

2)显式/隐式转换函数必须是static

为了更好的理解转换操作符和操作符重载方法,强烈建议将System.Decimal类型作为一个典型来研究。



本文转自wang_yb博客园博客,原文链接:http://www.cnblogs.com/wang_yb/archive/2011/06/30/2094048.html,如需转载请自行联系原作者

目录
相关文章
|
3月前
|
开发框架 .NET 程序员
C# 去掉字符串最后一个字符的 4 种方法
在实际业务中,我们经常会遇到在循环中拼接字符串的场景,循环结束之后拼接得到的字符串的最后一个字符往往需要去掉,看看 C# 提供了哪4种方法可以高效去掉字符串的最后一个字符
366 0
|
2月前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
130 65
|
1月前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
1月前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
73 3
|
1月前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
38 3
|
1月前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
63 1
|
2月前
|
存储 C#
【C#】大批量判断文件是否存在的两种方法效率对比
【C#】大批量判断文件是否存在的两种方法效率对比
52 1
|
1月前
|
编译器 C#
c# - 运算符<<不能应用于long和long类型的操作数
在C#中,左移运算符的第二个操作数必须是 `int`类型,因此需要将 `long`类型的位移计数显式转换为 `int`类型。这种转换需要注意数据丢失和负值处理的问题。通过本文的详细说明和示例代码,相信可以帮助你在实际开发中正确使用左移运算符。
18 0
|
2月前
|
C#
C# 可空类型(Nullable)
C# 单问号 ? 与 双问号 ??
62 12
|
2月前
|
算法 安全 测试技术
C#——刘铁猛笔记
C#——刘铁猛笔记
60 0