作为参数 c++ 的多级指针

Multi level pointer as argument c++

本文关键字:多级 指针 c++ 参数      更新时间:2023-10-16

我将在这里使用一个伪示例,尽管我已经在几个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 */
);

你的理解是错误的。

如果一个函数采用some_identifier **ppFubar;参数,它可能会在其函数体内的某个地方执行与some_identifier对象相关的操作。

如果你用some_identifier **ppFubar;调用它,你就给了它一个未初始化的指针,即一个指向垃圾的指针。如果函数对它执行任何操作(例如,它取消引用它,一次或两次),则会导致未定义的行为(最有可能的是,它会崩溃)。

将正确初始化的指针传递给函数。