在 C++ 中 指针变量的转换规则?
指针变量及不同指针类型的含义
指针变量
指针变量,本质上是一个变量,只是它是存放地址的变量,指针的类型代表的是它所指向的变量的类型。因此就有了指向整型、字符型、浮点型等其它类型的指针,但实际上所有类型的指针变量存放的都是int型。
上述代码表示指向整型的指针变量a,其中a表示一个地址值,上面曾提到地址没有明确的数据类型,因为地址可以为指向整型的指针,可以为指向浮点型的指针。指针类型为整型,表示当我们对该地址进行访问(解引用)时,编译器会将它解释为整型。
注意:指针地址只指向数据存储的内存的位置,具体变量的类型由编译器告知。
不同类型的指针
声明不同类型的指针变量既是规定了该变量结合指针运算符时读取内存中的字节数,同样规定了在指针移动和指针的运算时(加、减)在内存中移动的最小字节数。
普通变量强转
(float)a,就是先按照int类型取出该数值,再将该数值按照int to float的规则转换成float型,如果反过来,则会发生数据截断。
指针变量强转
旧指针 to 新指针的强制类型转换是指将指针所指的内容的类型由原先的类型转换为后面的类型:即进行变量解释的时候,解释的类型变化。
如果有一个指针p,我们需要把它的类型和所指向的类型改为TYEP和TYPE,那么语法格式是:(TYPE)p;这样强制类型转换的结果是一个新指针,该新指针的类型是TYPE*,它指向的类型是TYPE,(也就是说,新指针指向的数据将会用TYPE类型进行解释,如果之前是浮点型数据-3.75,先将其转换为二进制代码,然后转化为TYPE类型存储),它指向的地址就是原指针指向的地址。
//float指针相关的强制转换
//不同类型的指针变量,在内存中本质上都是一样的,都是一个整数值的地址值,一般表现为8位十六进制数
//不同的类型表示地址指向值的解释类型,及该变量在内存中占据字节的数目
//地址值可以强转为其他类型,但将地址指向值解释为其他类型容易出错,如float解释为int
void test02(){
//-----------------------------
//float指针相关的强制转换
//不同类型的指针变量,在内存中本质上都是一样的,都是一个整数值的地址值,一般表现为8位十六进制数
//不同的类型表示地址指向值的解释类型,及该变量在内存中占据字节的数目
//地址值可以强转为其他类型,但将地址指向值解释为其他类型容易出错,如float解释为int
//常量直接赋值给指针是不可以的,必须强转为合法地址,另外由于内存地址是整型值,因此浮点型数据不能成为合法地址
//-----------------------------
float a = 10.1;
float *p_ = &a;
cout << typeid(p_).name() << endl; //float*
cout << p_ << endl; //地址,8位十六进制数字(32位二进制数字)
cout << *p_ << endl; //地址指向的数据,同样为32位二进制数字,按照float进行解释,得到10.1
//cout << (float)p_ << endl; //不允许将地址直接转化为浮点型,但可以间接修改
cout << (char)p_ << endl; //直接将地址转化为字符型
cout << (int)p_ << endl; //直接将地址转化为十进制整型
cout << (int*)p_ << endl; //将地址float *类型转换为int*,后面的解释会发生变化,但地址的十六进制数字不会发生变化
cout << *(int*)p_ << endl; //地址指向的数据,会按照int型进行解释,得到1092721050
cout << (int&)(*p_) << endl; //同样的将数据解释为int型,得到1092721050, 则是告诉编译器将数据看成int对待
cout << *(int*)&p_ << endl; //将地址(8位十六进制数字)转换为十进制,先取p_的地址,然后按照int进行解释
cout << *(float*)&p_ << endl; //将地址(8位十六进制数字)转换为float,先取p_的地址,然后按照float进行解释
cout << *(float*)p_ << endl; //输出10.1
cout << (char*)p_ << endl; //将地址float*类型转换为char*类型,其实地址的十六进制数字不会发生变化,但<<会直接输出指向的字符串
cout << static_cast<const void *>(p_) << endl; //可以这样输出转换为char*后的地址
cout << *(char*)&p_ << endl; //将地址(8位十六进制数字)转换为char,先取p_的地址,然后按照char进行解释
cout << *(char*)p_ << endl; //将数值型数据按照字符类型,这里无法将float解释为char型,但是int型默认可以转换为ASCII码,解释为char型
}
作者:Then丶
链接:https://www.jianshu.com/p/3fb90255087d
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
https://www.jianshu.com/p/3fb90255087d
这个用法挺常见的,在该地址按照oop类型的字节大小取值
改成int就会按四字节int类型取值
指针类型不一样,取值的时候偏移量也会不一样,偏移量取决于指针类型
是不是这样:
int *p, double q,
p=(int)q
将 q强转成赋值p后,变量 p和q都指向同一个地址,只不过 p 变量的寻址是以int为单位,q是以double为单位