C++ gcc是否将单值的uint8\u t转换为int?
如果我编译以下程序:C++ gcc是否将单值的uint8\u t转换为int?,c++,gcc,c++11,implicit-conversion,type-conversion,C++,Gcc,C++11,Implicit Conversion,Type Conversion,如果我编译以下程序: #include <vector> #include <cstdint> #include <stdio.h> int main() { constexpr std::size_t N = 10; uint8_t int8Value = 42; std::vector<int> IntVector(N, 0); for (int & ele:IntVector) {
#include <vector>
#include <cstdint>
#include <stdio.h>
int main() {
constexpr std::size_t N = 10;
uint8_t int8Value = 42;
std::vector<int> IntVector(N, 0);
for (int & ele:IntVector) {
ele += int8Value;
}
std::vector<uint8_t> Int8Vector(N, 0);
for (uint8_t & ele:Int8Vector) {
ele += int8Value;
}
for (std::size_t i = 0; i < N; i++) {
printf("%i %i\n",IntVector[i],Int8Vector[i]);
}
}
因此,如果我理解正确,这意味着编译器将uint_8
的单个值转换为int
?这是因为内存对齐吗
另一方面,如果我尝试以下方法:
uint8_t int8Value = 342;
它向我抛出一个溢出
警告,并对结果进行分段。也
printf("%i\n",sizeof(int8Value));
返回预期的1
我遗漏了一些明显的东西吗?是的,算术表达式导致转换为
int
。请参见,例如:是,算术表达式导致转换为int
。参见,例如……好的,谢谢。因此,+
就是问题所在。线uint8\u t A=42,B=23,C=A+B代码>也会发出警告,以确认这一点。在性能方面我应该担心吗?@magu_uuu不,你不应该担心,它应该在编译时处理。@magu_uuu:通常在机器级别上没有单独的“8位”算术运算-编译器将在“本机”上发出做算术运算的代码单词和掩蔽,以获得最低的8位。好的,谢谢。因此,+
就是问题所在。线uint8\u t A=42,B=23,C=A+B代码>也会发出警告,以确认这一点。在性能方面我应该担心吗?@magu_uuu不,你不应该担心,它应该在编译时处理。@magu_uuu:通常在机器级别上没有单独的“8位”算术运算-编译器将在“本机”上发出做算术运算的代码获取最低八位所需的字和掩蔽。
printf("%i\n",sizeof(int8Value));