## 从某种意义上来说,所有的数据类型都是一种类
在日常编程中,我们都了解过,int类型转换成double类型,是一种隐式转换,double转换成int,则是一种显式转换。隐式转换是范围小的转范围大的,因为范围大的能够容纳范围小的,不会损失数据,所以编译器能够自动。而显式转换是范围小的转成范围大的,这个过程中会有数据的丢失,所以必须要我们用(int)来进行强制转换。
那么数据类型转换说的范围大的数据类型,范围小的数据类型是怎么看出来的呢?数据的丢失又是指什么呢?
范围大的数据类型就是指可以表达的数据更多,比如double类型既可以包含3,也可以包含3.1,也就是说所有的int类型都可以用double类型来表示,但所有的double类型却不能用int类型表示,比如说3.1。如果一定要把3.1变成int型,那么就会丢失小数点后面的数据0.1。
换个角度来讲,我们可以把范围大的数据类型看成是基类,范围小的数据类型看成是派生类。在C#中,一切皆是基于类实现的,所有的数据类型都是类。这样一切就解释的通了:因为范围大的数据类型是基类,范围小的类型是派生类,派生类是基于基类上又多定义了一些数据,相当于变得更加的实例化,多了一些的限制条件,因此范围会变小。
所以实际上,double和int都是类,而double是int的基类。
我们可以来测试一下,在main函数中写下如下c#代码(我是用C#试的,不能保证其他语言不会报错,感兴趣的朋友可以试试其他语言):
double i = new int();
i=5;
这跟我们用类定义一个对象的过程完全一样,运行后你会发现程序没有报错。