关于结构体指针类型转换的小结

关于结构体

结构体声明内存的分布,或者说是对特定内存区域的解读方式,

结构体指针声明结构体的首地址,并内含解读方式,

结构体成员声明该成员在结构体中的偏移地址。

 

两个问题:

1)    如果将一个结构体强制类型转换为另一个结构体(或者类型),那这个结构体的成员会怎样了?

2)    如果将一个结构体强制类型转换为另一个结构体(或者类型),那么这个结构体成员的数值又会是什么了?

 

内存中的数据(二进制机器码0、1)是独立存在的,不管是否有指针指向那块内存,它都存在。

指针所包含的两部分内容:1)定义解读方式,2)存储指向特定内存空间的首地址。不同类型的指针,可以包含相同的首地址,但解读方式并不相同。

 

举例1

当有指针a指向一块内存区域(如ram1)首地址时,机器就会按照指针a的定义类型,如float*a,对首地址之后的4个字节内存中的机器码,按照float的数据格式进行解读;

当指针a被赋值指向别的地址(如ram2)时,ram1中的数据并没有消失,只是指针a(作为一个变量)中的数据(地址)改变了。

 

代码示例与解读

  1. #include
  2. #include "cxcore.h"
  3. #include "highgui.h"
  4. #include "stdio.h"
  5. using namespace std;
  6. int main()
  7. {
  8. typedefstruct CvCARTClassifier
  9. {
  10. floata ;
  11. intb;
  12. }CvCARTClassifier;
  13. typedefstruct CvClassifier
  14. {
  15. floatc ;
  16. }CvClassifier;
  17. //定义指针
  18. CvCARTClassifier* tempcart;
  19. CvClassifier*temp;
  20. size_tdatasize = 0;
  21. datasize= sizeof( float)+ sizeof( int);
  22. tempcart= (CvCARTClassifier*)cvAlloc(datasize);
  23. datasize= sizeof( float) ;
  24. temp= (CvClassifier*)cvAlloc(datasize);
  25. //初始化赋值,并输出CvCARTClassifier结构体中的数值
  26. tempcart->a= 30;
  27. tempcart->b= 5;
  28. cout<< "a = "<< tempcart->a << endl;
  29. cout<< "b = " << tempcart->b << endl << endl;
  30. //将指向CvCARTClassifier结构体的指针,转换成指向CvClassifier类型的指针,并赋值给temp
  31. //并输出temp所指结构体中的成员数值
  32. temp=(CvClassifier*)tempcart;
  33. cout<< "a = " << temp->c << endl ;
  34. cout<< "a = " << tempcart->a << endl << endl;
  35. //将temp指针在转换成指向CvCARTClassifier类型的指针,并输出CvCARTClassifier结构体中的成员数值
  36. 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个字节的内存数据。还记得么,前面所讲指针的两层内容。


猜你喜欢

转载自blog.csdn.net/qfc8930858/article/details/81022930