C语言数据类型转换


前言

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

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

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

一、类型自动转换

在进行运算时,不同类型的数据要转换成同一类型。自动转换的规则如图在这里插入图片描述

转换方法为:

  1. float型数据自动转换成double型;
  2. char与short型数据自动转换成int型;
  3. int型与double型数据运算,直接将int型转换成double型
  4. int型与unsigned型数据、直接将int型转换成unsigned型;
  5. 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类型。

二、赋值转换

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

  1. 将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中
  2. 将实型数据(包括单、双精度)赋给整型变量时,舍弃实数的小数部分。如x为整型变量,执行“x=4.25”时,取值为x=4。
  3. 同类型的短数据赋值给长变量,自动转换是正确的,例如,char和short型数据给int型变量赋值。
  4. 同类型的长数据给短变量赋值可能出错。例如,当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

“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

第一个输出数据是字符变量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进行强制类型转换。

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值