C语言的数据转换

前言
C语言中,整型、单精度型、双精度型和字符型数据可以进行混合运算。字符型数据可以得与整型通用。例如:

100+′A′+8. . 65-2456. 75×′a′

是一个合法的运算表达式。在进行运算时,不同类型的数据要先转换成同一类型,然后再进行运算。C语言数据类型转换可以归纳成三种转换方式:自动转换,赋值转换和强制转换。

一、类型自动转换
在进行运算时,不同类型的数据要转换成同一类型。自动转换的规则如图

转换方法为:

float型数据自动转换成double型;
char与short型数据自动转换成int型;
int型与double型数据运算,直接将int型转换成double型
int型与unsigned型数据、直接将int型转换成unsigned型;
int型与long型数据,直接将int型转换成long型。
如此等等,总之是由低级向高级型转换。对于图中列出的自动类型转换,不要错误地理解为先将char型或short型转换成int型,再转换成unsigned型,再转换成long型,直至double型。例如,有如下定义:

char ch='a’
int i=13:
float x=3.65;
double y=7.528e-6;

若表达式为

i+ch+x*y

则表达式的类型转换是这样进行的:

先将ch转换成int型,计算i+ch,由于ch=‘a’,而‘a’的ASCH码值为97,故计算结果为110,类型为int型。再将x转换成double型,计算x*y,结果为double类型。最后将i+ch的值110转换成double型,表达式的值最后为double类型。

二、赋值转换
如果赋值运算符两侧的类型不一致,但都是数值型或字符型时,在赋值时要进行类型转换。转换的基本原则如下。

将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中
将实型数据(包括单、双精度)赋给整型变量时,舍弃实数的小数部分。如x为整型变量,执行“x=4.25”时,取值为x=4。
同类型的短数据赋值给长变量,自动转换是正确的,例如,char和short型数据给int型变量赋值。
同类型的长数据给短变量赋值可能出错。例如,当unsigned int型的值超过了int变量的取值范围,赋值会出错
例如:unsigned int 变量给int变量赋值出错

#include <stdio.h>
#include<windows.h>
void main()
{
unsigned int l= 4294967295 ;/*将最大的无符号整型数赋给变量1*/
int a;
a=l;/*将l的值赋给变量a*/
printf("%12d\n",a);/*输出变量a的值*/
system("pause");
}
输出结果为:
-1
1

“l= 4294967295 ”赋值给int型变量a,a的值却是-1。这是因为a是有符号数,最高位是符号位,为1表示该数是负数。
无符号整型数4294967295的32位二进制位都是1,而有符号int型-1用32位全1的二进制位表示。

#include<stdio.h>
#include<windows.h>
#include<math.h>
void main(){
char ch='A';//定义字符型变量,并赋初值‘A’
int a,b=3,c;//定义整型变量,并给变量b赋初值3
float x1,x2=2.5;//定义单精度浮点型变量
a=ch;//将字符型变量ch的值'A'赋给整型变量a
x1=a;
c=x2;//x2的值2.5赋给整型变量c
printf("%4c,%4d,%6.2f,%4d\n", ch,a,x1,c);//输出变量ch、a、x1和c的值getchar();
}
输出结果为:
A 65 65.00 2
1

 

第一个输出数据是字符变量ch的值字符’A’;第二个输出数据是整型变量a的值65,字符’A’的ASCII码转换成32位的整型数据;第三个输出数据是实型变量xl的值65.00,由int型变量a的值65自动转换成float类型;第四个数据是整型变量c的值,由实型变量x2的值2.5自动转换成整型数2。

三、强制类型转换
可以利用强制类型转换运算符将一个表达式转换成所需类型。如:

(double)x/*将x转换成double型*/
(int)(a+b)/*强制将a+b的值转换成整型*/
(float)(10%3)/*将10%3的值转换成float型*/

强制类型转换的一般形式为:
(类型名)(表达式)
例如:

int a=7,b=2;
float y1,y2;
float y1=a/b;/*y1的值a/b为3.0*/
y2=(float)a/b;/*y2的值为3.5,float将a进行强制转换为实型,b也随之自动转换为实型*/

(int)(x+y)和(int)x+y强制类型转换的对象是不同的。(int)(x+y)是对x+y进行强制类型转换;而(int)x+y则只对x进行强制类型转换。
C

posted @ 2022-10-11 23:43  kuailest  阅读(174)  评论(0编辑  收藏  举报