<char> 使用 int 值初始化向量

Initialize vector <char> with int values

本文关键字:向量 初始化 int gt lt char 使用      更新时间:2023-10-16

我想用此ASCII代码初始化此Char Vector:

vector <char> a = { 201, 187, 200, 188, 205, 186 };

我在所有6个字符中都会获得此语法错误:

从" int"到" char"的缩小转换无效:恒定值不适合目标类型

但是,当我初始化一个Char变量时,具有相同的ASCII代码:

char b = 201;

它可以正常工作。

所以我意识到在向量中,由于某种原因,char类型可以在127之前接收int值。开始128语法错误出现。

这与正常变量不同,当char类型可以接收任何int值时。

我尝试将矢量声明为未签名的char,而语法错误则消失。

vector <unsigned char> a = { 201, 187, 200, 188, 205, 186 };

但仍然,

为什么char类型向量无法接收与char类型变量相同的int数据?

我真的很感谢有人解释我这种行为。

有两件事。

1
第一个是char类型的默认值范围,它是实现定义的。在大多数主要编译器中,默认值为[-128,127]。(奇怪的是,这与不像signed char,JSYK!)

MSVC和GCC都提供了将char视为签名或未签名的选项。您可以这样做以在全球解决问题。

更好的是,不要假设char处理范围之外的任何内容[0,127]。使用signed charunsigned char是特定的。

2
第二个是您正在使用支撑初始化,该初始化需要检查字面元素值以拟合范围。

为您的示例:

std::vector <char> xs = { 201, 202 };  // compiler error
char x { 201 };  // compiler error
char x = 201;  // compiler warning

如果您没有编译器的错误级别(并且应该),那么编译器将默默地忽略该警告并分配该值,即使它在技术上无效。

没有内置的方法可以做到这一点,因为字符文字仅以单引号为单,而数字(无后缀)是ints。您可以添加L,LL,UL,ULL来制作一个字面的长,长长的且未签名的版本,以及其他一些用于浮点等的版本,但是没有此类后缀。

但是,如果您有C 11或以后的编译器,则可以编写自己的用户定义的文字来帮助:

constexpr char operator "" _c(unsigned long long arg) noexcept
{
    return static_cast<char>(arg);
}
int f()
{
  std::vector <char> a = { 201_c, 187_c, 200_c, 188_c, 205_c, 186_c };
}

如果这不是一个选项,或者您只是不喜欢它,您总是可以写一个普通的功能来做类似的事情:

constexpr char c(int arg) noexcept
{
    return static_cast<char>(arg);
}
int f()
{
  std::vector <char> a = { c(201), c(187), c(200), c(188), c(205), c(186) };
}