我将在这里使用一个伪示例,尽管我在几个 API 中注意到了这种行为,比如 sqlite3 或 windows。
假设一个函数是这样声明的:
void Fu(some_identifier **ppBar);
我在我的代码中这样做:
some_identifier **ppFubar;
fu(ppFubar);
据我了解,这会起作用,而且确实在我自己的功能中起作用。然而,当我使用某些 API 执行此操作时,我的程序在缓冲区溢出后崩溃。
如果我这样做:
some_identifier *pFubar;
fu(&pFubar);
一切都很好。
ppFubar 和 &pFubar 的评估结果是否完全相同?
编辑:
一个具体的例子是(第四个参数):
int sqlite3_prepare(
sqlite3 *db, /* Database handle */
const char *zSql, /* SQL statement, UTF-8 encoded */
int nByte, /* Maximum length of zSql in bytes. */
sqlite3_stmt **ppStmt, /* OUT: Statement handle */
const char **pzTail /* OUT: Pointer to unused portion of zSql */
);