关于结构体指针类型转换的小结
2017-02-12 13:09
435 查看
关于结构体
结构体声明内存的分布,或者说是对特定内存区域的解读方式,结构体指针声明结构体的首地址,并内含解读方式,
结构体成员声明该成员在结构体中的偏移地址。
两个问题:
1) 如果将一个结构体强制类型转换为另一个结构体(或者类型),那这个结构体的成员会怎样了?
2) 如果将一个结构体强制类型转换为另一个结构体(或者类型),那么这个结构体成员的数值又会是什么了?
内存中的数据(二进制机器码0、1)是独立存在的,不管是否有指针指向那块内存,它都存在。
指针所包含的两部分内容:1)定义解读方式,2)存储指向特定内存空间的首地址。不同类型的指针,可以包含相同的首地址,但解读方式并不相同。
举例1
当有指针a指向一块内存区域(如ram1)首地址时,机器就会按照指针a的定义类型,如float*a,对首地址之后的4个字节内存中的机器码,按照float的数据格式进行解读;当指针a被赋值指向别的地址(如ram2)时,ram1中的数据并没有消失,只是指针a(作为一个变量)中的数据(地址)改变了。
代码示例与解读
#include #include "cxcore.h" #include "highgui.h" #include "stdio.h" using namespace std; int main() { typedefstruct CvCARTClassifier { floata ; intb; }CvCARTClassifier; typedefstruct CvClassifier { floatc ; }CvClassifier; //定义指针 CvCARTClassifier* tempcart; CvClassifier*temp; size_tdatasize = 0; datasize= sizeof(float)+sizeof(int); tempcart= (CvCARTClassifier*)cvAlloc(datasize); datasize= sizeof(float) ; temp= (CvClassifier*)cvAlloc(datasize); //初始化赋值,并输出CvCARTClassifier结构体中的数值 tempcart->a= 30; tempcart->b= 5; cout<< "a = "<< tempcart->a << endl; cout<< "b = " << tempcart->b << endl << endl; //将指向CvCARTClassifier结构体的指针,转换成指向CvClassifier类型的指针,并赋值给temp //并输出temp所指结构体中的成员数值 temp=(CvClassifier*)tempcart; cout<< "a = " << temp->c << endl ; cout<< "a = " << tempcart->a << endl << endl; //将temp指针在转换成指向CvCARTClassifier类型的指针,并输出CvCARTClassifier结构体中的成员数值 cout<< "b = " << ((CvCARTClassifier*)temp)->b <
输出结果为:
程序解读部分
CvCARTClassifier* tempcart;
tempcart中存储CvCARTClassifier结构体的首地址,假设一个CvCARTClassifier结构体所占据的内存空间命名为ram1,并按照CvCARTClassifier定义的内部结构,对tempcart所指地址之后的内存空间进行解读。
因此前两行输出是:30,5
当执行temp=(CvClassifier*)tempcart;这句话包含两层内容
1) 内存rma1中的数据并没有改变,
2) tempcart中存储的CvCARTClassifier结构体的首地址,赋值给了temp
那么,机器对CvCARTClassifier结构体中成员a的访问输出,可以通过两种方式,两者是等价的,
cout<< temp->c << endl;
cout<< tempcart->a << endl << endl;
其条件是,tempcart和temp指向了相同的首地址,并且CvCARTClassifier和CvClassifier结构体中第一个成员类型相同,即均为float。
但是,机器对CvCARTClassifier结构体中成员b的访问输出,只有一种方式,
cout <<tempcart->b<< endl << endl;
因为,根据CvClassifier结构体定义的内部结构,通过temp所指的首地址,机器只能解读后面的4个字节的内存数据。还记得么,前面所讲指针的两层内容。
参考文献:http://blog.csdn.net/kokodudu/article/details/13004951
相关文章推荐
- 关于指针强制类型转换的思考
- 关于内存和指针操作,数据类型转换本质的理解
- 关于stl::vector中存储带指针类型成员的结构体指针
- C++结构体中关于结构体变量,指针,地址之间的转换
- 结构体相关的计算(结构体指针加一以及强制类型转换后加一)
- C语言中不同类型的结构体的指针间可以强制转换
- 关于C中字符数组,字符指针以及C++中string类型的两两转换及排序
- 关于函数指针类型强制转换的一些摸索
- 关于指针强制类型转换的思考
- 关于指针类型转换的一个有趣实验
- 关于int类型指针和char类型指针相互转换问题
- C++中 关于结构体中有char *类型的指针 赋值问题
- 关于void编程规范、void*(指针)、(void*)类型转换的详解
- 关于对 (char *)字符指针强制转换类型的一些理解
- 关于各种字符类型的指针的转换
- C语言中关于指针的数据类型和指针运算的小结
- 关于内存和指针操作,数据类型转换本质的理解
- 关于内存和指针操作,数据类型转换本质的理解
- 2017.08.13指针小结+自定义数据类型(结构体、共用体、枚举、typeof)理论
- 关于结构体与类型转换的一点小技巧