当从定义文件访问不透明结构内部的结构时,我遇到了一个奇怪的分段错误。我最近刚刚了解了不透明指针,但我的猜测是,我在分配内部结构时做错了。但是,在第一次调用该结构时,它似乎可以工作,并且在同一方法中无法访问它。
所以我在里面定义了我的不透明结构指针connection.h
:
#ifndef _Connection_h
#deifne _Connection_h
// Connection opaque pointer
typedef struct connection;
// API
_Bool connection_connect(struct connection *self);
#endif // _Connection_h
然后在connection.c
我内部分配serv
type 的内部结构指针struct sockaddr_un
。
#include "../connection.h"
struct connection {
_Bool (*connect)();
char *(*get_name)();
char name[MAX_NAMELEN];
char hostname[MAX_NAMELEN];
uint serv_id;
struct sockaddr_un *serv; // Server socket structure
};
// ** Public Interface **
_Bool connection_connect(struct connection *self) {
printf("Generic connection (opaque pointer)..\n");
strcpy(self->name, SERVERNAME);
// Socket path
char path[108];
strcpy(path, SERVERNAME);
strcat(path, "_socket");
printf("self->name = %s\n", self->name);
// Allocate the serv socket structure
self->serv = malloc(sizeof(*self->serv));
strcpy(self->serv->sun_path, path);
self->serv->sun_family = AF_UNIX;
printf("self->serv->sun_path = %s\n", self->serv->sun_path);
printf("self->serv->sun_family = %hn\n", self->serv->sun_family);
// Locate the host
char hostname[MAX_NAMELEN];
gethostname(hostname, MAX_NAMELEN);
strcpy(self->hostname, hostname);
if ((self->serv_id = socket(AF_UNIX, SOCK_STREAM, 0)) == -1)
handle_error("Socket");
return 1;
}
connection
然后接口方法的分配由客户端处理。对于最小的可重现示例,client
类型实现可以像这样处理接口方法分配:
#include "../connection.h"
typedef struct connection {
void (*connect)();
} *client;
void client_connect(client self) {
connection_connect(self);
printf("Client connection..\n");
}
client make_client(client self) {
client tmp = malloc(sizeof(client));
tmp->connect = client_connect;
return tmp;
}
// Main procedure
int main(int argc, char **argv) {
client c = make_client(c);
c->connect(c);
return 0;
}
执行后,分配的结构首先似乎被正确分配,并且它的实例可以访问,直到最后一个printf
:
Generic connection (opaque pointer)..
self->name = freebay
self->serv->sun_path = freebay_socket
[1] 210938 segmentation fault (core dumped)
(gdb) p self->serv
$1 = (struct sockaddr_un *) 0x66203d2068746170
(gdb) x self->serv
0x66203d2068746170: Cannot access memory at address 0x66203d2068746170
我的问题是,为什么self->serv
在同一方法中使用它后无法访问?