我正在尝试使用来自C的libpq创建数据库连接。如果我使用PQconnectdb创建该连接,一切正常,但如果我使用PQconnectdbParams函数创建它,只有以不同方式存储的相同参数(看到libpq reference这个),我得到一个分段错误错误,没有任何其他消息。在这个问题上有人可以帮助我吗?
你可以看到我的代码:
int main(int argc, char *argv[]) {
char **keywords;
char **values;
char *line = malloc(50);
char *prop, *tmp, *val;
int i = 0, j = 0;
FILE *creds = fopen("/path/to/file.props", "r");
if (creds == NULL) {
LOG("%s", "error: cannot open credentials file.\n");
exit(1);
}
keywords = malloc(5 * sizeof(*keywords));
values = malloc(5 * sizeof(*values));
while (fgets(line, LINE_SIZE, creds) != NULL) {
if (line[strlen(line) - 1] == '\n')
line[strlen(line) - 1] = '\0';
prop = line;
while(*(prop++) != '=') {
i++;
}
tmp = prop;
prop = malloc(i + 1);
strncpy(prop, line, i);
prop[i] = '\0';
keywords[j] = prop;
val = malloc(strlen(line) - strlen(prop) + 1);
strcpy(val, tmp);
values[j++] = val;
i = 0;
}
printf("%s %s %s %s %s\n", keywords[0], keywords[1], keywords[2], keywords[3], keywords[4]); //that lines prints ok
printf("%s %s %s %s %s\n", values[0], values[1], values[2], values[3], values[4]); //
PGconn *conn = PQconnectdbParams(keywords, values, 0);
if (PQstatus(conn) != CONNECTION_OK) {
fprintf(stderr, "Connection to database failed: %s", PQerrorMessage(conn));
PQfinish(conn);
exit(1);
}
}
答案 0 :(得分:5)
PQconnectdbParams
的文档说:
此函数使用参数打开新的数据库连接 取自两个以NULL结尾的数组。
但在您的代码中,keywords
和values
数组似乎不以NULL结尾。
它为5个参数分配了5个指针,但它应该为5个参数分配6个指针加上一个NULL指针。