gpt4 book ai didi

c++ - libmysql:警告:返回局部变量 ‘rows’ 的地址 (C++/C)

转载 作者:太空宇宙 更新时间:2023-11-04 06:10:20 26 4
gpt4 key购买 nike

我正在使用 g++。

为方便我使用 libmysql 实现了一些包装器。还制作 C/C++ 兼容代码。

static MYSQL_RES *db_query(MYSQL *db, const char *query, va_list params) {
char q[500];
vsprintf(q, query, params);
va_end(params);
if (mysql_query(db, q)) {
fprintf(stderr, "%s\n", mysql_error(db));
return NULL;
}

MYSQL_RES *res = mysql_use_result(db);
return res;
}

MYSQL_ROW* db_query_all(MYSQL *db, const char* query, ...) {
va_list params;
MYSQL_RES *res = db_query(db, query, params);

int count = mysql_num_rows(res);

MYSQL_ROW rows[count];
for (int i = 0; i<count; i++)
{
rows[i] = mysql_fetch_row(res);
}

mysql_free_result(res);
return rows;
}

并在编译期间收到警告:

warning: address of local variable ‘rows’ returned [-Wreturn-local-addr]
MYSQL_ROW rows[count];

请帮我找出问题所在。我无法用谷歌搜索与我的特定案例相关的内容。

最佳答案

更多的 C++ 方法是定义一个 movable缓冲区类型:

struct Buf {
Buf(size_t size) : mPtr(std::make_unique<MYSQL_ROW[]>(size)), mSize(size) {}

std::unique_ptr<MYSQL_ROW[]> mPtr;
size_t mSize;
};

然后你可以这样实现这个功能:

Buf db_query_all(MYSQL *db, const char* query, ...) {
va_list params;
MYSQL_RES *res = db_query(db, query, params);

int count = mysql_num_rows(res);

Buf rows(count);
for (int i = 0; i<count; i++)
{
rows.mPtr[i] = mysql_fetch_row(res);
}

mysql_free_result(res);
return std::move(rows);
}

这种方法的一大优点是您不必进行手动内存处理。

关于c++ - libmysql:警告:返回局部变量 ‘rows’ 的地址 (C++/C),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58335356/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com