‘壹’ 请问c语言如何实现数据类型的强制转化
强制类型转换
当操作数的类型不同,而且不属于基本数据类型时,经常需要强制类型转换,将操作数转化为所需要的类型。强制类型转换具有两种形式,称为显式强制转换和隐式强制类型转换。
1、显式强制类型转换
显式强制类型转换需要使用强制类型转换运算符,格式如下:
type(<expression>)
或
(type)<expression>
其中,type为类型描述符,如int,float等。<expression>为表达式。经强制类型转换运算符运算后,返回一个具有type类型的数值,这种强制类型转换操作并不改变操作数本身,运算后操作数本身未改变,例如:
int nVar=0xab65;
char cChar=char (nVar);
上述强制类型转换的结果是将整型值0xab65的高端两个字节删掉,将低端两个字节的内容作为char型数值赋值给变量cChar,而经过类型转换后nVar的值并未改变。
2、隐式强制类型转换
隐式类型转换发生在赋值表达式和有返回值的函数调用表达式中。在赋值表达式中,如果赋值符左右两侧的操作数类型不同,则将赋值符右边操作数强制转换为赋值符左侧的类型数值后,赋值给赋值符左侧的变量。在函数调用时,如果return后面表达式的类型与函数返回值类型不同,则在返回值时将return后面表达式的数值强制转换为函数返回值类型后,再将值返回,如:
int nVar;
double dVar=3.88;
nVar=dVar;//执行本句后,nVar的值为3,而dVar的值仍是3.88
1,若已知x,y为double类型,则表达式:x=1,y=x+3/2结果是多少啊?
因为x,y都是double型,所以执行了y=x+3/2这个语句后,会输出小树部分,double型默认的是小数点后几位我忘了,你自己调试下,就会明白了!
‘贰’ c语言强制转换的疑问
应该是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型变量。
‘叁’ C语言中,函数指针的强制类型转换有什么作用
函数指针强转尽量不要有,仅用于类型实际是相同的,但定义的变量类型不同,如
另一个程序员写了段代码,要求你提供一个函数指针,类型如下:
typedef int (*ftype)(int,int);
但你写的函数是 unsigned int fun(unsigned int,unsigned int),参数一个有符号,一个无符号,在你知道符号不影响结果的情况下,可以强制转换。
‘肆’ C语言中int(a)与(int)a与(int)(a)都可以强制将a转换为int吗
是。是。是。
‘伍’ C语言强制类型转换
强制类型转换是把变量从一种类型转换为另一种数据类型。
例如,如果想存储一个long类型的值到一个简单的整型中,需要把long类型强制转换为int类型。可以使用强制类型转换运算符来把值显式地从一种类型转换为另一种类型。
发生在同一个编译系统中,比如说把int转化为longint,在VC++6.0里面,longint和int都是4个字节,不会有问题的,但是如果把int类型转化为short类型那就装不下了,简而言之就是长类型不能转化为短类型。
int类型如果要转化为float、double、longdouble类型的时候只是末尾多了几个0,但是反之转化,就会出现数据的损失,小数部位都被省略掉了。
赋值中的类型转换
当赋值运算符两边的运算对象类型不同时,将要发生类型转换, 转换的规则是:把赋值运算符右侧表达式的类型转换为左侧变量的类型。
由于C语言中的浮点值总是用双精度表示的,所以float 型数据只是在尾部加0延长为double型数据参加运算,然后直接赋值。double型数据转换为float型时,通过截尾数来实现,截断前要进行四舍五入操作。
以上内容参考:网络-C语言类型强制转换
‘陆’ c语言强制类型转换
1、int a;int b;double c = (double) a;double c = (double) b;int a = (int) c;这就是一种强制转变方法。
‘柒’ C语言函数指针的强制转换有什么作用
如果你把sub函数改为int sub(int a, int b,int c,int d,int e,int f,int g,int h),你就会发现后面那几个参数就变得不正常,道理很简单,参数PUSH过少,函数传递参数是把参数PUSH进堆栈,在函数题里面再POP出来,至于什么作用我也不大清楚,也许是想得到堆栈的数据,不过最好不要这么用。