在看rob hess 的sift代码时看到这样的结构,因为对c++没什么深刻的了解,所以不是很明白,查了下。
struct feature
{
。。。
void* feature_data; /**< user-definable data */
};
feature结构中有一个void指针。void指针可以指向任意结构,不过在读取指针指向的值时必须进行强制类型转换。
代码中有这样的转换代码
#define feat_detection_data(f) ( (struct detection_data*)(f->feature_data) ),
能看懂代码,对渊源不了解。也佩服c++的用法。
不过下面的代码
ddata = feat_detection_data( feat );直接把指针转化成一个detection_data的指针,这个做法提高了feature结构的灵活度。
但是事先没有给这个指针区域分配内存。
一般的用法如下
1.int nValue = 5;
2.void *pVoid = &nValue;void指针指向了一个内存区域。但是本例中,没有指向一个内存区域。只是一种指针指向的数据类型的转换。随后就直接对这个区域进行读写。void指针是如何分配内存的呢。
本文探讨C++中void指针的使用方式,特别是在结构体中作为通用数据存储的应用。通过具体示例解释如何将void指针转换为特定类型,并讨论这种做法如何提高代码灵活性。
690

被折叠的 条评论
为什么被折叠?



