我是靠谱客的博主 调皮航空,最近开发中收集的这篇文章主要介绍C语言基础隐式类型转换与强制类型转换示例解析,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

类型转换

数据有不同的类型,不同类型数据之间进行混合运算时必然涉及到类型的转换问题。

转换包括隐式类型转换和强制类型转换。

类型转换的原则:占用内存字节数少(值域小)的类型,向占用内存字节数多(值域大)的类型转换,以保证精度不降低。

隐式类型转换

隐式转换也称为自动转换,遵循一定的规则,由编译器自动完成。
C的整型算数运算总是至少以缺省整型类型的精度来进行,为了获得这个精度,表达式中的字符和短整形操作数在使用之前都被转换成普通整型,这种转换为整型提升。

整型提升:通用CPU是难以直接实现两个8比特位直接相加运算。所以表达式中各种长度可能小于int长度的整型值,都必须转换为int或者unsigned int ,然后才能送入CPU去执行运算。

代码示例1:

int main()
{
	char a = 5, b = 126;
	//5:00000000 00000000 00000000 00000101
	//a:0000 0101(截断操作)
	//126:00000000 00000000 00000000 01111110
	//b:0111 1110
	//当a和b相加时,都是char类型,就会发生整型提升
	//int c = 000000000000000000000000 00000101 + 000000000000000000000000 01111110
	//char c = 10000011(整型截断)
	//以%d 打印,再次在内存中整型提升,再打印原码
	//int c = 11111111111111111111111110000011(补码)
	//打印原码:10000000000000000000000011111101
	char c = a + b;
	printf("%dn", c);
	return 0;
}

如何整型提升:按照变量的数据类型的符号位来提升。

代码示例2:

//负数的整型提升
char s1 = -1;
变量s1的二进制补码中只有8个比特位 11111111
因为char是有符号的,所以在整型提升的时候,高位补充符号位
即:11111111 11111111 11111111 11111111
//正数的整型提升
char s2 = 1;
变量s2的二进制补码中只有8个比特位 00000001
因为char是有符号的,所以在整型提升的时候,高位补充符号位
即:00000000 00000000 00000000 00000001

无符号数的整型提升,高位直接补0;

代码示例3:

隐式转换

int main()
{
	int num = 5;
	printf("s1=%dn", num / 2);
	printf("s2=%lfn", num / 2.0);
	return 0;
}
s1=2
s2=2.500000
请按任意键继续. . .

强制类型转换

强制类型转换指的是使用强制类型转换运算符,将一个变量或表达式转化成所需的类型

代码示例1:

#include <stdio.h>
int main()
{
	float x = 0;
	int i = 0;
	x = 3.6f;
	i = x;			//x为实型, i为整型,直接赋值会有警告
	i = (int)x;		//使用强制类型转换
	printf("x=%f, i=%dn", x, i);
	return 0;

OK!!!观众老爷们,这里只是介绍了有关类型转换的入门知识,如果朋友们觉得有一点点作用的话,希望朋友们能够给予小菜鸟一点支持!后续继续给朋友们带来更好的博文,还希望朋友们能够继续关注,小菜鸟致力于把自己的学习经验与个人理解更多的分享给大家,望大家喜欢与指正,请大家以后多多支持靠谱客!

最后

以上就是调皮航空为你收集整理的C语言基础隐式类型转换与强制类型转换示例解析的全部内容,希望文章能够帮你解决C语言基础隐式类型转换与强制类型转换示例解析所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(98)

评论列表共有 0 条评论

立即
投稿
返回
顶部