作为参数 c++ 的多级指针
Multi level pointer as argument c++
我将在这里使用一个伪示例,尽管我已经在几个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;
调用它,你就给了它一个未初始化的指针,即一个指向垃圾的指针。如果函数对它执行任何操作(例如,它取消引用它,一次或两次),则会导致未定义的行为(最有可能的是,它会崩溃)。
将正确初始化的指针传递给函数。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 为什么使用 "this" 指针调用派生成员函数?
- 函数向量_指针有不同的原型,我可以构建一个吗
- 使用指针从C++中的数组中获取最大值
- 助记符和指向成员语法的指针
- 嵌入方指针压缩已禁用
- 数组的指针从不分段故障
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 何时在引用或唯一指针上使用移动语义
- QMetaObject invokeMethod的基于函数指针的语法
- 如何从 std::atomic 中提取指针 T<T>?
- 如何在 C# 中映射双 C 结构指针?
- 读取进程内存多级指针(DLL 注入)
- 如何包装多级原始指针以赋予其容器语义
- 作为参数 c++ 的多级指针
- 解引用多级指针
- 引用多级指针的更好方法
- 在具有多级指针和偏移的C++中使用WriteProcessMemory()
- C++、作弊引擎/OllyDBG从多级指针中查找基础"static"地址