c语言强制转换的疑问

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言强制转换的疑问相关的知识,希望对你有一定的参考价值。

a=bit(gaq&0x8000)这个句子咋看不懂 就是别的强转换都明白就这个不懂bit的想不明白

应该是keil
c里面的。在keil
c里bit是一位的,属于对标准c扩展的数据类型。我举个例子说明bit的强制转换规则,例如有变量unsigned
char
num,变量bit
tmp,那么tmp
=(bit)
num就是把unsigned
char型变量强制转换为bit型,不过规则有点和一般的强制转换不一样,bit进行强制转换时,只要num不等于0(或者0x00),那么tmp
=(bit)
num的结果就是1,自然地如果num=0,那么tmp=0。你这个a=bit(gaq&0x8000)我没猜错的话应该是要得到gaq的每一位,而且下面会有类似gaq
<<
=
1(或者gaq
=
gaq
<<
1;)的语句,gaq是个unsigned
int型变量。
参考技术A &位运算 按位与

把变量gaq的 第0位到第30位都清零保留 第31位(最高位)

强制转换为 (80C51单片机C的数据类型,位类型 )bit 型本回答被提问者采纳
参考技术B 有意思

C语言自动类型转换

参加+-×/的运算中,有一个数为double,所有其他数字都变为double再运算,还是直到运算到该double数时才开始转换为double

您好,是这样的:
1. 在表达式中,char 和 short 类型的值,无论有符号还是无符号,都会自动转换成 int 或者 unsigned int(如果 short 的大小和 int 一样,unsigned short 的表示范围就大于 int,在这种情况下,unsigned short 被转换成 unsigned int)。因为它们被转换成表示范围更大的类型,故而把这种转换称为“升级(promotion)”。
2. 按照从高到低的顺序给各种数据类型分等级,依次为:long double, double, float, unsigned long long, long long, unsigned long, long, unsigned int 和 int。这里有一个小小的例外,如果 long 和 int 大小相同,则 unsigned int 的等级应位于 long 之上。char 和 short 并没有出现于这个等级列表,是因为它们应该已经被升级成了 int 或者 unsigned int。
3. 在任何涉及两种数据类型的操作中,它们之间等级较低的类型会被转换成等级较高的类型。
4. 在赋值语句中,= 右边的值在赋予 = 左边的变量之前,首先要将右边的值的数据类型转换成左边变量的类型。也就是说,左边变量是什么数据类型,右边的值就要转换成什么数据类型的值。这个过程可能导致右边的值的类型升级,也可能导致其类型降级(demotion)。所谓“降级”,是指等级较高的类型被转换成等级较低的类型。
5. 作为参数传递给函数时,char 和 short 会被转换成 int,float 会被转换成 double。使用函数原型可以避免这种自动升级。
参考技术A 先转换,在运算,向位数宽的转换,有符号向无符号转换。本回答被提问者采纳

以上是关于c语言强制转换的疑问的主要内容,如果未能解决你的问题,请参考以下文章

请教一下有关C语言用(float)强制转换的用法

c和c++中,对结构体进行强制类型转换!

C语言 int转char

C语言自动类型转换

C语言的多态是不是是类似于用结构指针的强制转换来实现的,具体实现方式类似于Linux万能链表???

关于强制类型转换(c语言)