初始化字符* 与整数*

Initializing char* vs int*

本文关键字:整数 初始化 字符      更新时间:2023-10-16

在C++中是可能的:

const char* ch = "hello";

但是这样的事情是不可能的:

int* i = { 1, 2, 3 };

char *chint* i都是普通指针。为什么char*可以分配多个字符,而int*不能分配多个整数?

我知道我们可以使用

int x[] = {1, 2, 3};

但这不是问题所在。

const char* ch = "hello";

有点像

static const char string_literal[] = { 'h', 'e', 'l', 'l', 'o', '' };
const char* ch = &string_literal[0];

除了每个相同的字符串文本不一定指向内存中的不同位置。

对于任何其他类型也是如此:

static int integer_list[] = { 1, 2, 3 };
int* i = &integer_list[0];
// or equivalently, just int* i = integer_list;

现在,i[0] 1i[1] 2i[2] 3

字符串文字有一种特殊的语法,因为它们非常频繁地使用,并且在不希望用虚拟变量混淆代码的上下文中非常频繁。

如果您有很多代码使用静态分配的整数类型的只读数组,则可以使用模板隐藏样板:

template <int a, int b, int c>
struct int_array { static const int values[3]; };
template <int a, int b, int c>
const int int_array<a, b, c>::values[] = { a, b, c };

您只需定义一次模板,然后每个不同的用户都可以将该模板用于用户感兴趣的特定值。

const int* i = int_array<1, 5, 6>::values;

通常,简单地定义一个单独的数组变量会更容易,但在某些情况下,这样的模板会有所帮助。

如注释中所述,可以更通用地定义模板,以便它适用于任意类型和任意长度的数组,但它需要一个最新的编译器,并且很好地支持当前版本的C++(对于 GCC 和 clang,当前版本很好,但请确保通过 -std=c++11-std=gnu++11 选项以启用 C++11 功能(:

template <typename T, T... v>
struct static_array {
  static const T values[sizeof...(v)];
};
template <typename T, T... v>
const T static_array<T, v...>::values[sizeof...(v)] = { v... };

现在,此数组用户的语法是

const int* i = static_array<int, 1, 2, 3, 4>::values;
const unsigned* j = static_array<unsigned, 1, 2, 3, 4, 5>::values;

字符串文本是一个字符数组。请注意,ch只是指向单个字符的指针,因此它实际上并不指向整个字符串,而只是指向其基址(第一个字符的地址(。初始值设定项列表(即{1, 2, 3}(不是数组,因此不能用于初始化指针。

字符文本编译为二进制文件的数据段中的一段初始化存储。 const char *是指向该存储的指针。

事实上,应该可以对const int *做同样的事情,只要你有内存块的地址。 您可以使用内联汇编器(但我从未尝试过(指定.data段来执行此操作。