关于结构体
结构体声明内存的分布,或者说是对特定内存区域的解读方式,
结构体指针声明结构体的首地址,并内含解读方式,
结构体成员声明该成员在结构体中的偏移地址。
两个问题:
1) 如果将一个结构体强制类型转换为另一个结构体(或者类型),那这个结构体的成员会怎样了?
2) 如果将一个结构体强制类型转换为另一个结构体(或者类型),那么这个结构体成员的数值又会是什么了?
内存中的数据(二进制机器码0、1)是独立存在的,不管是否有指针指向那块内存,它都存在。
指针所包含的两部分内容:1)定义解读方式,2)存储指向特定内存空间的首地址。不同类型的指针,可以包含相同的首地址,但解读方式并不相同。
举例1
当有指针a指向一块内存区域(如ram1)首地址时,机器就会按照指针a的定义类型,如float*a,对首地址之后的4个字节内存中的机器码,按照float的数据格式进行解读;
当指针a被赋值指向别的地址(如ram2)时,ram1中的数据并没有消失,只是指针a(作为一个变量)中的数据(地址)改变了。
代码示例与解读
-
-
-
-
-
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 <
输出结果为:
程序解读部分
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个字节的内存数据。还记得么,前面所讲指针的两层内容。