字符串数组的内存分配

memory allocation for array of strings

本文关键字:分配 内存 数组 字符串      更新时间:2023-10-16

据我所知,数组是静态分配的,但字符串是动态的,因为它们的长度在运行时经常变化。

当我像这样定义一个数组时会发生什么呢?

std::string array[] = {"abc", "defghi", "jk", "lmnop", "qrstuvwxyz"}; ?

是否为每个字符串分配有限的内存?还是数组是动态分配的?

不要想太多。当您说T x[N];时,您声明了一个自动(即范围局部)数组。这非常类似于仅仅声明T x1;, T x2;,…, T xN;std::string的实例在其声明上下文中总是占用相同的小大小(例如在堆栈上);只有它所管理的内存(默认在自由存储中)是动态的。

请注意,当您在代码中编写std::string s("Hello");时,那么字符串字面量(传递给构造函数)当然存储在程序二进制中的某个地方,并且它被加载到程序内存中(通常是只读数据段)。因此,如果您真的只需要读取这些字符串(而不是修改它们),那么您不妨声明一个char指针数组,从而节省一些内存:

const char * strings[] = { "Hello", "World", "!" };   // just one copy in r/o memory

Literal字符串存储在二进制的数据段中。

编辑:

ildjarn的评论说得好。std::字符串由数组中的复制构造函数创建。它们的存储位置取决于实现。一些实现将小字符串(少于32个字符)内联存储在数组中。其他将从std::allocator进行分配,该allocator通常是从堆中malloc取出的。

在这种情况下,编译器将这些文字放在ELF二进制文件的.data部分中。因此,在这种情况下,它们是在您创建的可执行(或库)文件中静态分配的。

.data部分通常保留给编译时常量,这些常量不只是硬编码到汇编指令中。正如您所看到的,简单地将地址保存到字符串中要比将它放在使用它的任何地方便宜得多(就像一些整数和定义的宏所做的那样)。