在C语言中,unsigned char是啥类型

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在C语言中,unsigned char是啥类型相关的知识,希望对你有一定的参考价值。

unsigned char是无符号字节型,char类型变量的大小通常为1个字节(1字节=8个位),且属于整型。整型的每一种都有无符号(unsigned)和有符号(signed)两种类型(float和double总是带符号的),在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型的话就需要在类型前加上unsigned。无符号版本和有符号版本的区别就是无符号类型能保存2倍于有符号类型的数据,比如16位系统中一个int能存储的数据的范围为-32768~32767,而unsigned能存储的数据范围则是0~65535。
同样,在32位系统中一个char类型一般为8个bit,所以能存储的数据范围为-128~127,而unsigned char则是0~255,字符型所存储的数据是用来表示字符的,例如ASCⅡ或Unicode。
关于char的符号(选自thinking in C++ 2nd vol1):
signed is the default and is only necessary with char; char may or may not default to signed. By specifying signed char, you force the sign bit to be used.
译:有符号类型是默认(指的是对于其他整型来说)的类型并且仅对于char来说才是必须的。char有可能是signed也有可能是unsigned(我想这可能取决于编译器或具体实现)。但通过显式地指定一个char为signed,你就迫使其成为有符号的字符型(水平太烂译的不好请见谅
参考技术A 无符号字符型,占1个字节,就是8bit。所以大小范围是0到255 参考技术B 无符号字符型。
unsigned是无符号的意思
char是字符型,存符号或字母。
参考技术C unsigned char是无符号字节型,char类型变量的大小通常为1个字节(1字节=8个位),且属于整型。整型的每一种都有无符号(unsigned)和有符号(signed)两种类型(float和double总是带符号的),在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型的话就需要在类型前加上unsigned。无符号版本和有符号版本的区别就是无符号类型能保存2倍于有符号类型的数据,比如16位系统中一个int能存储的数据的范为-32768~32767,而unsigned能存储的数据范围则是0~65535。
同样,在32位系统中一个char类型一般为8个bit,所以能存储的数据范围为-128~127,而unsigned char则是0~255,字符型所存储的数据是用来表示字符的,例如ASCⅡ或Unicode。
关于char的符号(选自thinking in C++ 2nd vol1):

signed
is the default and is only necessary with char; char may or may not
default to signed. By specifying signed char, you force the sign bit to
be used.

译:有符号类型是默认(指的是对于其他整型来说)的类型并且仅对于char来说才是必须的。char有可能是signed也有可能是unsigned(我想这可能取决于编译器或具体实现)。但通过显式地指定一个char为signed,你就迫使其成为有符号的字符型

在定义整数变量的型态的时候可以加上 unsigned 或是 signed, 例如 unsigned char unsigned short
(int) unsigned long (int) unsigned int ---------- signed char signed
short (int) signed long (int) signed int -------------- 上面 signed
有加和没有加是一样的意义 加上 unsigned 以后, 1. 所需要的数据储存空间和没有加 unsigned 时是一样的 2. 在使用
printf() 打印时基本上你必须分清楚 unsigned 有影响到的是参数的传递, 使用 %d 或是 %u 基本上是看程序设计者自己的选择
int i=-1; printf("%d %u/n", i, i); 会印出 -1 4294967295 unsigned int i=-1;
printf("%d %u/n", i, i); 也会印出 -1 4294967295 char i=-1; printf("%d %u/n",
i, i); 还是会印出 -1 4294967295 但是 unsigned char i=-1; printf("%d %u/n", i,
i); 则会印出 255 255 这不是 %d 和 %u 的问题, 而是 参数传递时数据转换的问题 (见下面第 3 项) 不一样的地方有下面几个
1. 数据的范围基本上加上 unsigned 以后会变成 2 倍 2. 程序里比较大小的时候 int i=1; int j=-1; if
(i>j) printf("i>j/n"); else printf("i<=j/n"); 你会发现结果是 i>j
unsigned int i=1; int j=-1; if (i>j) printf("i>j/n"); else
printf("i<=j/n"); 你会发现结果是 i<=j 也就是说 signed 和 unsigned 在比较的时候
compiler 会把 signed int 自动当成 unsigned int 来比较 2. 数据转换的时候 (或是函式呼叫的时候) char
i = -128; int j = i; 变量 i 里面的数据只有 1 个字节, 要放进 变量 j 里面的时候需要做 sign
extension 也就是多出来的 3 个字节 (24 个 bit) 都要 填入原来 i 的 sign bit (第 8 个 bit)
以上例来说 (用二进制表示) i: 10000000 j: 11111111 11111111 11111111 10000000
unsigned char i = -128; int j = i; 由 unsigned 转为 signed 时前面一率补 0 用二进制表示
i: 10000000 j: 00000000 00000000 00000000 10000000 char i = -128;
unsigned int j = i; 还是做 sign extension 用二进制表示 i: 10000000 j: 11111111
11111111 11111111 10000000 函式呼叫的时候会做型态的转变, 例如 void fun(int x) ...
呼叫时如果用 unsigned char i=-1; fun(i); 就会自动做转换本回答被提问者采纳

如何获取一个unsigned char*类型的字符串长度

  有两种方式:

  1 使用数据类型强制转换,示例带如下:

unsigned char s[100] = "abcdef";
int len = strlen((char*)s);

  2 另外一种方式就是自己实现该方法,进行统计。

  对于C/C++中的字符串,必须是以'\\0'结尾的,因此可以如下做

int getLen(const unsigned char s[])

    int nLen = 0;
    const unsigned char* p = s;
    while(*p!=0)
        nLen++;
        p++;
    
    return nLen;

参考技术A char*转换

Qt下面,字符串都用QString,确实给开发者提供了方便,想想VC里面定义的各种变量类型,而且函数参数类型五花八门,经常需要今年新那个类型转换
Qt再使用第三方开源库时,由于库的类型基本上都是标准的类型,字符串遇的多的就是Char*类型
在Qt下怎样将QString转char*呢,需要用到QByteArray类,QByteArray类的说明详见Qt帮助文档。
因为char*最后都有一个‘/0’作为结束符,而采用QString::toLatin1()时会在字符串后面加上‘/0’
方法如下:
Qstring str;
char* ch;
QByteArray ba = str.toLatin1();
ch=ba.data();
这样就完成了QString向char*的转化。经测试程序运行时不会出现bug
注意第三行,一定要加上,不可以str.toLatin1().data()这样一部完成,可能会出错。

补充:以上方法当QString里不含中文时,没有问题,但是QString内含有中文时,转换为char*就是乱码,采用如下方法解决:
方法1:
添加GBK编码支持:
#include <QTextCodec>
QTextCodec::setCodecForTr(QTextCodec::codecForName("GBK"));
QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"));
然后改变上面的第三行为:QByteArray ba = str.toLoacl8Bit(); toLoacl8Bit支持中文
方法2:
先将QString转为标准库中的string类型,然后将string转为char*,如下:
std::string str = filename.toStdString();
const char* ch = str.c_str();本回答被提问者和网友采纳
参考技术B 有两种方式:
1 使用数据类型强制转换,示例带如下:

1
2

unsigned char s[100] = "abcdef";
int len = strlen((char*)s);

2 另外一种方式就是自己实现该方法,进行统计。
对于C/C++中的字符串,必须是以'\0'结尾的,因此可以如下做

1
2
3
4
5
6
7
8
9
10

int getLen(const unsigned char s[])

int nLen = 0;
const unsigned char* p = s;
while(*p!=0)
nLen++;
p++;

return nLen;

以上是关于在C语言中,unsigned char是啥类型的主要内容,如果未能解决你的问题,请参考以下文章

在C语言中,unsigned char是啥类型?

在C语言中,unsigned char是啥类型

在C语言中,unsigned char是啥类型

char是啥类型

unsigned char 和 signed char 区别

在 c语言中int long unsigned 和 char这四种类型数据的转换规律是_____.