等号是否以字符*重新分配内存
Does the equal sign reallocate memory in a char *?
如果我使用以下代码char * foo = "words"
。我应该先调用free()
,然后再调用:foo = "two words";
。这个代理人是如何工作的?是否释放了包含字符串"word"的内存,然后分配了足够的内存来容纳字符串"two-words",然后将foo设置为指向新字符串。我只想确保我的代码尽可能高效,并且没有任何内存泄漏。
否,您应该只为通过malloc
、calloc
或realloc
分配的对象调用free
。
"words"
是一个具有静态存储持续时间的对象,您无法释放该对象。
无需调用free()
。事实上,它会失败。像这样声明的字符串常量不在堆中,并且将在程序的整个生命周期中存在。
在程序使用malloc()
等分配的内存上调用free()
。
如果我使用以下代码
char * foo = "words"
。我应该先呼叫free()
吗:foo = "two words";
。
没有。free
的参数必须是以前由malloc
、calloc
或realloc
函数返回的指针。否则,它将调用未定义的行为。
这项任务是如何完成的?
当编译器遇到长度为n
的字符串文字时,它会为该字符串留出n+1
字节的内存。当字符串文字被分配给char
指针时,它指向已分配内存的第一个字节
一旦存储在内存中,字符串文字在程序的整个生命周期内都是可用的
如果将"two words"
后一个分配给foo
,则word
仍将继续存储在该部分,但该部分与malloc
分配的位置不同。
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?