[英]Incomplete type when dereferencing pointer C
我有一个给出定义的头文件
typedef struct dyn_array dyn_array_t
我有一个实现它的.c文件
struct dyn_array {
size_t size;
void* array;
};
在另一个.c文件中,我将此类型的指针传递给函数。
bool first_come_first_serve(dyn_array_t* ready_queue){
size_t limit = ready_queue->size;
//...
}
我无法弄清楚我在做什么错。
另一个.c文件看不到struct dyn_array
定义。 它对size
成员没有任何了解。
如果需要多个.c文件来了解结构,请将以下内容移至.h文件
struct dyn_array {
size_t size;
void* array;
};
另一种方法是创建一个获取成员的函数,并将dyn_array_t
的定义保留在dyn_array.c
。 这是信息隐藏 -一个好的设计目标。
// in dyn_array.h
typedef struct dyn_array dyn_array_t;
size_t get_size(const dyn_array_t* ready_queue);
// in different.c
#include <dyn_array.h>
bool first_come_first_serve(dyn_array_t* ready_queue){
size_t limit = get_size(ready_queue);
//...
}
// in dyn_array.c
#include <dyn_array.h>
struct dyn_array {
size_t size;
void* array;
};
size_t get_size(const dyn_array_t* ready_queue) {
return ready_queue->size;
}
“不完整的类型”表示您仅声明/使用了该类型,而没有对其进行解释。 您的第二个.c
文件可能#include "ah"
但请注意dyn_array
的定义在ac
而不是ah
要解决此问题, dyn_array
在ah
声明并定义dyn_array
:
struct dyn_array {
size_t size;
void* array;
};
编译器需要完成类型定义,才能取消指向它的指针并访问其字段。 您必须将类型定义放在标头中(可能与用于放置typedef
声明的标头不同),并将其也包含在第二个文件中,以便能够通过指针进行访问。 编译器允许您访问不完整类型定义的指针,只要您不需要该类型的详细信息即可。 与第二个文件一样,编译器对结构的构造一无所知,因此无法访问size
字段。
如果您需要代码的某些部分无法访问数据类型的内部详细信息,而其他部分完全了解它,则可以准备两个头文件(一个公共文件,另一个私有文件),如下所示:
typedef struct dyn_array dyn_array_t;
size_t get_size(const dyn_array_t* ready_queue);
#include "dynarry.h"
struct dyn_array {
size_t size;
void *array;
};
然后,在用作客户端的模块中,该库仅包含"dynarry.h"
,而在内部实现中,您#include "dynarryP.h"
。 关于隐藏内部实现细节 ,这有点类似于面向对象的编程。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.