1、有符号少字节赋给有符号多字节时,将其放置低位字节,高位字节补符号位。
2、无符号字符型赋给整型变量时,将其放置低位字节,高位字节补0;
3、有符号字符型赋给整型变量时,将其放置低位字节,高位字节补符号位。
4、可以理解为转换是以二进制为基础的,然后符号位根据原类型来确定。在取值范围内一般不会出现问题,超出取值范围就会出现错误。
一、
#include <iostream>
int main(){
// 将右边的数字转换为二进制再赋予
unsigned char a1 = -1;
signed char a2 = -1;
// 类型自动转换
std::cout<<(int)a1<<" "<<(int)a2<<std::endl;
if(a1 == a2){
std::cout<<"ok";
}
return 1;
}
会将-1转化为补码11111111形式,然后在向有符号int类型转换时,对于unsigned char,高位补0;signed char高位补符号位。打印时按照有符号int型打印
输出:
255 -1
--------------------------------
二、
#include <iostream>
int main(){
unsigned char a1 = 128;
// 数值溢出
signed char a2 = 128;
std::cout<<(int)a1<<" "<<(int)a2<<std::endl;
if(a1 == a2){
std::cout<<"ok";
}
return 1;
}
128在无符号char的取值范围内,没问题。但128超出有符号char型,二进制为10000000,此时赋给有符号int,高位扩展符号位,变成-128。
输出:
128 -128
--------------------------------
三、
#include <iostream>
int main(){
unsigned char a1 = 256;
signed char a2 = 256;
std::cout<<(int)a1<<" "<<(int)a2<<std::endl;
if(a1 == a2){
std::cout<<"ok";
}
return 1;
}
输出:
0 0
ok
--------------------------------