深入理解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/p/2697400.html