有符号一个字节取值范围

有符号一个字节最大和最小值

1Byte=8bit
一个字节八个位,有符号值,符号位占用1位【二进制表示=X,XXX XXXX】
计算机用1表示负数,0表示正数,用补码表示负数
正数
补码=原码
负数
补码=原码除去符号位(1位)其他各个位取反再在末尾+1
比如:
-1
原码:10000001
补码:111111110+1=11111111
  1. 最大值
    最大值肯定为正数,正数符号位为0所以第一位为0
    0,XXXXXXX
    那么数值位肯定全为1
    即(0,1111111)b=(2^7-1=127)d
  2. 最小值
    同理:最小值为负数,符号位:1
    1,XXXXXXX
    这边需要注意和正数不一样
    错误想法
    (1,1111111)b=(-127)d
    其实应该是:1,0000000)b=(-128)d
    我们反推
    -(128)
    =(-1)+(-127)
    =(1,0000001)原+(1,1111111)原
    =(1,1111111)补+(1,0000001)补
    =1,0000000

现在我们正过来看
-128的原码=1,0000000
补码=(1,1111111)+1=1,0000000
会发现一个字节刚刚好能够表示,所以最小值为-128
即:有符号一个字节表示的范围为:【-128,127】

### 字符在Word文档中的字节大小 Microsoft Word 文档使用的文件格式主要基于二进制结构,对于字符的存储方式取决于所采用的具体编码标准。当考虑纯文本内容时,在Word文档中每个字符的实际占用空间会受到多种因素的影响。 #### ASCII 和 ANSI 编码下的字符 对于仅包含基本拉丁字母和其他常见符号的情况,这些字符通常按照ANSI编码来处理,这与Windows平台上的GBK或ISO-8859系列相似。在这种情况下: - 英文字符以及其他一些控制字符(如空格)占据 **1个字节**[^3]。 #### Unicode 编码下的字符 现代版本的Word默认使用Unicode作为内部字符集表示方法之一,这意味着它可以很好地支持多语言文本输入。具体来说: - 对于UTF-16LE编码模式下: - 单个英文字符仍然只需要 **2个字节**; - 中文字符同样需要 **2个字节** 或者更多(针对某些特殊字符可能达到4个字节),因为这是为了确保能够覆盖整个UCS-2范围内的所有字符以及BMP平面之外的部分字符。 需要注意的是,除了上述提到的内容外,实际Word文档还包含了丰富的格式化信息、样式表单、图片等多种非文本元素,因此整体文件体积往往会远大于单纯计算其中可见字符数量所能得出的结果。 另外,由于Word采用了压缩技术保存.docx格式文件,所以即使知道每种类型字符的确切字节数量也无法直接推断出最终生成文件的真实大小。 ```javascript // JavaScript示例用于说明如何估算字符串长度(并非适用于Word) function estimateByteSize(str){ let byteCount = 0; for(let i=0;i<str.length;i++){ const codePoint = str.codePointAt(i); if(codePoint >= 0xD800 && codePoint <= 0xDBFF){ // Surrogate pairs check i++; // Skip next surrogate pair component } byteCount += (codePoint > 0xFFFF)?4:(codePoint>0xFF?2:1); } return byteCount; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值