我有一个名为myArchive
的C ++程序,它从静态C库中调用例程。
我的myArchive
代码有一个名为Archive
的类,其中包含一个名为md
的私有变量,其类型为Metadata *
,在我的C库中定义。
这是myArchive.hpp
标题:
#ifndef MYARCHIVE_H
#define MYARCHIVE_H
#include "myLibraryHeaders.h"
...
namespace Archive {
class Archive {
public:
Archive();
virtual ~Archive();
Metadata * getMd() { return md; }
Metadata ** getMdRef() { return &md; }
void setMd(Metadata *_md) { md = _md; }
private:
Metadata *md;
};
Archive::Archive() {
md = NULL;
}
Archive::~Archive() {
if (md != NULL)
freeMetadata(&md);
}
}
#endif
freeMetadata()
函数只是释放链表中的项目:
void freeMetadata(Metadata **md) {
Metadata *iter;
Metadata *prev = NULL;
if (! *md)
return;
for (iter = *md; iter != NULL; iter = iter->next) {
/* ... */
if (prev != NULL)
free(prev);
prev = iter;
}
if (prev != NULL) {
free(prev);
prev = NULL;
}
}
以下是myLibraryHeaders.h
中引用的其中一个标头中的声明:
#ifdef __cplusplus
extern "C" {
#endif
#ifndef METADATAHELPERS_H
#define METADATAHELPERS_H
typedef struct metadata {
/* ... */
struct metadata *next;
} Metadata;
/* ... */
void freeMetadata(Metadata **md);
/* ... */
#endif
#ifdef __cplusplus
}
#endif
我还有一些其他变量,但这是与我的问题相关的内容,即:
当我尝试编译它时,我得到一个超出范围的错误:
...
g++ -D_FILE_OFFSET_BITS=64 -D_LARGEFILE64_SOURCE=1 -DUSE_ZLIB -DUSE_BZLIB -O3 -Wformat -Wall -Wswitch-enum -static -c myArchive.cpp -o myArchive.o
myArchive.hpp: In destructor "virtual myArchive::Archive::~Archive()":
myArchive.hpp:87: error: "freeMetadata" was not declared in this scope
make: *** [myArchive] Error 1
但我包含一个声明myLibraryHeaders.h
的头文件(在freeMetadata()
中)。此外,编译器没有抱怨Metadata
类型,它本身也在myLibraryHeaders.h
的一个标题中定义。
我错过了什么或做错了什么?
答案 0 :(得分:0)
唯一有意义的解释是你在myLibraryHelpers.h的包含之前以某种方式定义METADATAHELPERS_H
,可能是由于某些先前包含某个地方 - 某种循环包含依赖。您可以尝试使用g++ -E
提取预处理后的文本并尝试查看是否可以解决问题(搜索freeMetaData出现在哪里以了解您最终的顺序) ),但总的来说解决这些问题可能很棘手