关于结构体
结构体声明内存的分布,或者说是对特定内存区域的解读方式,
结构体指针声明结构体的首地址,并内含解读方式,
结构体成员声明该成员在结构体中的偏移地址。
两个问题:
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 <
<< endl;
getchar();
return0;
}
#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 <
<< endl;
getchar();
return0;
}
输出结果为:
程序解读部分
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