C++与动态内存分配混淆
C++ confusing with Dynamic memory allocation
_Groups = (group **) new char[sizeof (group **) * NOMGRPS];
以上是我阅读的实际代码。我只是想知道如果我这样做有什么差异
_Groups = new group*[sizeof (group **) * NOMGRPS];
_Groups = (group **) new char[sizeof (group **) * NOMGRPS];
这为NOMGRPS
组指针创造了足够的空间,并将其强制转换为指向group**
的指针,大概用作分配给其他地方的 group
类型的对象的指针数组。 这是(或更严格地说,是(一个常见的习语,因为char
几乎总是一个字节,所以这说"分配sizeof (group **) * NOMGRPS
字节(足够的字节用于NOMGRPS
组指针(并将其强制转换为指向组指针的指针。 因此,如果NOMGRPS
是 10,并且您使用的是 32 位系统,具有 4 个字节指针,则分配 40 个字节。
_Groups = new group*[sizeof (group **) * NOMGRPS];
这里不是说你想要 40 char
s(即字节(,而是说你想要 40 group*
. 因此,如果NOMGRPS
为 10,并且您使用的是具有 4 个字节指针的 32 位系统,则分配 40 * 4 或 160 个字节。 这几乎肯定不是您想要的,但由于它过度分配内存,因此它可能会正常工作。 你做出这种改变的直觉是正确的。 任何时候你用现代C++铸造,你都应该认为它是可疑的。 但你走得还不够远。
你真正想要的是这个:
_Groups = new group*[NOMGRPS];
new
知道group*
的大小,因此会为其中NOMGRPS
分配足够的资源。 这比使用new char
的原始版本更正确。
我不明白这段代码的意图。我的猜测是为NOMGRPS
指向group
的指针分配内存,即您需要(指针大小NOMGRPS
*字节(内存。
如果是这样,那么这个
_Groups = (group **) new char[sizeof (group **) * NOMGRPS];
做你想做的事。虽然以错误的方式。它为(指针大小NOMGRPS
*大小(字符分配内存。char
的大小是 1 个字节,这就是为什么这条线可以做你想要的。但:
1(您需要为指针分配内存,而不是字符。
2(您需要为group *
指针分配内存,而不是group **
。所以sizeof (group **)
错了。
_Groups = new group*[sizeof (group **) * NOMGRPS];
这将为指针分配内存(NOMGRPS
* 指针大小(,这不是您想要的。
有效方式:
_Groups = new group *[ NOMGRPS ];
它为NOMGRPS
指向group
的指针分配内存。任务完成。
(Point **) new char[10]
分配内存十char
秒,然后将指针转换为指向Point*
的指针。如果sizeof(char) != sizeof(Point*)
,这可能会崩溃,因为分配的数组大小错误。所以这是完全错误的。
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?