gpt4 book ai didi

如果变量为 NULL,则有条件地设置它

转载 作者:行者123 更新时间:2023-12-04 12:01:49 24 4
gpt4 key购买 nike

当单步执行 sqlite3_stmt 时,我想检查 NULL 的返回值,而不是存储它并检查存储的值。

这是我现在正在做的:

char *email = (char *)sqlite3_column_text(statement, 10);
if (email == NULL) email = "";

下面是我喜欢做的,减去对 column 的双重调用:

char *email = ((char *)sqlite3_column_text(statement, 10)) ? (char *)sqlite3_column_text(statement, 10) : "";

有没有什么方法可以更简洁地表达第二个表达式?我必须重复做很多这样的事情,所以我力求简洁。

我知道这是控制流的问题,而不是 SQLite API 本身的问题,但你知道了。我想不出执行此操作的好方法。

最佳答案

A GNU extension to C如果条件为真且第一个分支中没有任何内容,则允许三元条件运算符对其条件求值:

char *email = (char *)sqlite3_column_text(statement, 10);
email = email ? : "";

或者,更准确地说,你正在寻找什么

char * email = (char *)sqlite3_column_text(statement, 10) ? : "";

这在使用 Clang 编译时也有效。

另一种可能性是:

char *email = (char *)sqlite3_column_text(statement, 10);
email = (NULL == email) ? email : "";

但我认为我建议您只选择第一个选项。如果您经常这样做,请制作一个代码片段。

关于如果变量为 NULL,则有条件地设置它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15121336/

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