字、半字、字节的定义

定义字是根据处理器的特性决定的。
首先ARM是32bit处理器,所以它的字是32bit的。半字自然就是16bit;
字节不论在哪个CPU上都是8bit。
如果在MSP430上,由于它是16bit处理器,所以它的字是16bit的。半字=字节=8bit。
CPU按照其处理信息的字长可以分为:八位微处理器、十六位微处理器、三十二位微处理器以及六十四位微处理器等。

CPU最大能查找多大范围的地址叫做寻址能力,CPU的寻址能力以字节为单位,如32位寻址的CPU可以寻址2的32次方大小的地址也就是4G,这也是为什么32位的CPU最大能搭配4G内存的原因,再多的话CPU就找不到了。


下面有一个问题:int应该是2还是4?VC++ 默认 int 是 long int, 长度是4TC    默认 int 是 short int, 长度是2
int类型所占的字节数依赖于机器的字长, 有16位, 32位, 64位.我们现在买电脑时所说的32位机, 64位机就是指这个, 在16位机上int长度是2, 在32位机上长度是4, 所以在编码的时候需要写int长度时, 我们不能想当然的写2或4, 而应使用sizeof来计算, sizeof(int)这样就不会错了, 而且提高了程序的健壮性
### 四、双符与字节的含义及区别 #### 字节 (Byte) 字节是计算机处理数据的基本单位,由8个比特组成。每个字节能表示0到255之间的整数值,在ASCII编码体系下可以表示128种不同的符[^2]。 #### 单 (Word) 单通常指两个连续的字节组成的单元,即16位的数据量。这取决于具体平台架构;对于某些特定环境而言也可能定义为其他大小,比如32位系统上的word可能指的是四个字节长度的数据结构。 #### 双 (Double Word, DWord) 双是指由两个相邻的words构成的一个更大的地址空间部分,一般等于32 bits 或者说4 Bytes 的容量。它能够容纳更大范围内的数值,并且常用于寄存器操作以及内存寻址等方面。 #### 四 (Quad Word, QWord) 四是由八个字节(64 bit)所形成的大规模数据块。这种类型的变量主要用于高性能计算领域内,当涉及到非常庞大的数运算时会显得尤为重要。 #### 多字节符集(Multi-byte Character Set, MBCS) 多字节符集中存在一些特殊符需要用超过一个字节来表达其完整意义的情况。例如UTF-8编码下的汉占用三个甚至更多字节的空间,而UTF-16则可能是两至四个不等的数量级变化。特别是提到的`wchar_t`类型,在不同平台上可能会被实现为两种宽度之一——要么总是固定占据两个字节的位置,要么支持完整的Unicode标准并因此允许达到最大四位数的跨度[^1]。 ```c++ // C++ 中 wchar_t 类型的例子 #include <iostream> int main() { wchar_t wch = L'😊'; // 这里假设编译器默认使用 UTF-32 编码方式,则该表情符号会被视为单一 4-bytes 宽度的符 std::wcout << "Size of wchar_t: " << sizeof(wchar_t) * CHAR_BIT << "-bits\n"; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值