深入理解C指针四(指针类型转换)--By kmalloc

---------------------------指针类型转换--------------------------------------
没有隐式转化这一说,都要进行强转;
如果有一个指针p,我们需要把它的类型和所指向的类型改为TYEP* 那么语法格式是: 
  (TYPE*)p 
  这样强制类型转换的结果是一个新指针,该新指针的类型是TYPE*,它指向的类型是TYPE,它指向的地址就是原指针指向的地址。而原来的指针p的一切属性都没有被修改。 
  一个函数如果使用了指针作为形参,那么在函数调用语句的实参和形参的结合过程中,也会发生指针类型的转换。 
    例7
void fun(char*); 
int a=125, b; 
fun((char*)&a); 
... 
... 
void fun(char *s) 

char c; 
c=*(s+3);*(s+3)=*(s+0);*(s+0)=c; 
c=*(s+2);*(s+2)=*(s+1);*(s+1)=c; 


注意这是一个32位程序,故int类型占了四个字节,char类型占一个字节。函数fun的作用是把一个整数的四个字节的顺序来个颠倒。注意到了吗?在函数调用语句中,实参&a的结果是一个指针,它的类型是int*,它指向的类型是int。形参这个指针的类型是char*,它指向的类型是char。这样,在实参和形参的结合过程中,我们必须进行一次从int*类型到char*类型的转换。结合这个例子,我们可以这样来想象编译器进行转换的过程:编译器先构造一个临时指针char*temp 然后执行temp=(char*)&a,最后再把temp的值传递给s。所以最后的结果是:s的类型是char*,它指向的类型是char,它指向的地址就是a的首地址。
[Note]编译器会自动用形参来转换指针的类型.

想想能不能反过来,把指针指向的地址即指针的值当作一个整数取出来。完全可以。下面的例子演示了把一个指针的值当作一个整数取出来,然后再把这个整数当作一个地址赋给一个指针: 
  例8 
int a=123, b; 
int *ptr= &a; 
char *str; 
b=(int)ptr;//把指针ptr的值当作一个整数取出来。 
str=(char*)b;//把这个整数的值当作一个地址赋给指针str
现在我们已经知道了,可以把指针的值当作一个整数取出来,也可以把一个整数值当作地址赋给一个指针。

转载于:https://www.cnblogs.com/qinkai/archive/2012/09/21/2697400.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值