在视频教程中,你已经认识到了数字类型之间、字符串和其他类型之间的转换。而某些时候,我们还需要将char类型转换为int类型,或者把int类型转换为char类型。
这篇文章,将介绍在代码中虽然不太常用,但也需要了解的知识。
char转为int
一个字符 ‘汉’ 怎么可能转换为数字呢?
实际上是可以的,在之前的补充资料中已经说到,计算机对字符的存储,是使用某种编码规则对应的数字来存储的。
在C#语言中,使用Unicode编码来存储字符。
比如汉字 ‘汉’,对应的Unicode编码是27721,在计算机内存中,将使用汗27721对应的二进制来存储。
因此,如果要把 ‘汉’ 转换为int类型的数字,转换的结果就是27721。
那使用什么样的代码来完成该转换呢?
char类型的任何数据都可以隐式的转换为int类型。
既然是隐式转换,所以,下面的代码都是正确的:
char c = ‘汉‘;int n = c;Console.WriteLine(n);n = ‘a‘;Console.WriteLine(n);
运行上面的代码,会输出:
2772197
说明 ‘汉’ 和 ‘a’ 在Unicode编码中分别是27721和97。
为什么char类型的数据赋值给int类型的变量可以使用隐式转换呢?
是因为char类型的数据在内存中存储时使用的是Unicode编码,Unicode编码占16位(两个字节),而int类型占32位(4个字节)。因此,char类型的数据占位少,取值范围小,而int类型的数据占位多,取值范围大。所以,这样的赋值是安全的,不会造成数据丢失,可以隐式转换。
int转为char
比如,我有一个int类型的变量27721,我想看看这个数字作为编码,对应的字符是什么?
这种情况,就需要把int类型的数据转换为char类型。
int类型的数据转换为char类型时必须使用显示转换。
为什么必须使用显示转换呢?如果你看懂了char转为int一节,应该明白原因。
char类型的取值范围小于int,因此,将取值范围大的int类型转换为取值范围小的char类型是不安全的,所以要用显示转换。
下面的代码,是查看27721和97两个数字所代表的字符:
int n = 27721;char c = (char)n;Console.WriteLine(c);c = (char)97;Console.WriteLine(c);
字符数据的运算
char类型的数据,在进行数学运算(+、-、*、/、%)时,会将它当做int进行运算,运算的返回类型是int。
也就是说,字符也可以参与数学运算,在运算的时候,会把这个字符的编码进行运算,运算的返回结果是一个整数int。
比如,’a’+’1’,这个代码计算的是’a’的编码加上’1’的编码,返回的是编码相加的整数。’a’的编码是97,’1’的编码是49,计算结果是一个int类型的整数146。
下面的代码可以很好的说明这一点。
int a = ‘a‘+‘1‘;Console.WriteLine(a);
运行后会输出146。
再比如,想想下面的代码运行后会输出什么呢?
int a = ‘a‘+1;char c = (char)a;Console.WriteLine(c);
分析一下:
- ‘a’+1,是将a的编码加上1,结果为98,将98保存到变量a中。
- 然后,将98转换为对应的字符,转换的结果就是字符’b’,将其保存到变量c中。
- 最后输出变量c,就输出了字符b。
char类型的数据,在进行数学运算(+、-、*、/、%)时,会将它当做int进行运算,运算的返回类型是int。这种做法,叫做自动类型提升,实际上,不仅仅是char,取值返回比int类型小的数字类型,比如byte、short,它们也适用于自动提升规则。
比如,两个byte类型的变量进行数学运算时,也会将它们当做是int类型运算,返回结果也是int。
byte s1 = 2, s2 = 3;byte s3 = s1 + s2;
上面的第二句代码会报错,提示你int无法赋值给byte。就是因为两个byte的变量s1和s2,在进行数学运算时,会提升为int类型,它们计算的结果是一个int类型,不能隐式转换赋值给byte类型的变量s3。
之所以这样做,是因为像byte这些取值范围很小的类型,如果不提升,它们在运算时经常会导致结果超过其取值范围,超过的部分丢失掉了,得到了错误的数据。而提升为取值范围更大的int类型后,会在很大程度上解决这一问题。