char类型的数值转换

时间:2022-05-23 23:32:19

在视频教程中,你已经认识到了数字类型之间、字符串和其他类型之间的转换。而某些时候,我们还需要将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);

运行上面的代码,会输出:

27721
97

说明 ‘汉’ 和 ‘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类型后,会在很大程度上解决这一问题。