陷阱之有符号与无符号

2024-04-12 16:18
文章标签 陷阱 符号 之有

本文主要是介绍陷阱之有符号与无符号,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

请看下面这段代码:

#include <stdio.h>
#include<string.h>
int main(int argc, char **argv)
{char a[1000];int i;for(i = 0;i < 1000;i++){a[i] = -1 - i;}printf("%c\n",a[190]);    1printf("%c\n",a[254]);   2printf("%c\n",1);         3printf("%d\n",strlen(a));printf("%d\n",i);printf("%d\n",a[i]);return 0;
}

打印值:
255
1000
-24
对于这个结果大家一定很困惑吧,可能只有中间一个结果大家还能接受。
这里主要用到了补码的知识。
首先为什么第一个值是255呢?
首先a[0]的值是-1,关键就是-1在内存中是如何存储的呢?我们知道在计算机中,数值一律用补码来表示,主要原因是使用补码,可以将符号位和其他位统一处理;同时,减法也可按照加法来处理。另外,两个补码表示的数相加时,如果高位有进位,则进位被舍弃。
补码的规则:
正数的补码与其原码一致,负数的补码符号位(最高位)为1,其余位为该数绝对值的原码按位取反,然后再加1。
按照补码的规则,可以知道-1的补码是0xff,-2的补码是0xfe……当i的值为127时,a[127]的值是-128,而-128是char类型数据能表示的最小的负数。当i继续增加,a[128]的值肯定不能是-129。因为这时候发生了溢出,-129需要9位才能存储下来,而char类型数据只有8位,所以最高位被舍弃。剩下的8位是9位补码的低8位的值,即0x7f。当i继续增加到255的时候,-256的补码的低8位为0。所以从a[0]到a[254]的值都不为0,而a[255]刚好为字符0(即\0),所以strlen的长度是从a[0]到a[254],结果为255。
而最后那个a[i](i = 1000)只是一个随机值。

这篇关于陷阱之有符号与无符号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897624

相关文章

C++学习笔记----6、内存管理(四)---- 通常的内存陷阱(2)

3、Windows环境下使用Visual C++发现并修复内存渗露         内存渗露很难跟踪是因为你无法很容易地看着内存并且看到什么对象处于使用中,一开始在哪儿分配的内存。然而,是有程序可以为你做到这一点的。内存渗露检测工具有昂贵的专业软件包,也有免费下载的工具。如果你是在Microsoft Visual C++环境下工作,它的排错工具库有内建的对于内存渗露检测的支持。该内存检测默认没有

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密 可以将表情,动物,水果,表情,手势,猫语,兽语,狗语,爱语,符号,数字,字母,加密和解密 可以将文字、字母、数字、代码、标点符号等内容转换成新的文字形式,通过简单的文字以不同的排列顺序来表达不同的内容 源码截图: https://www.httple.net/152649.html

用异或交换两个整数的陷阱

前面我们谈到了,可用通过异或运算交换两个数,而不需要任何的中间变量。 如下面: void exchange(int &a, int &b) {     a ^= b;     b ^= a;     a ^= b; } 然而,这里面却存在着一个非常隐蔽的陷阱。 通常我们在对数组进行操作的时候,会交换数组中的两个元素,如exchang(&a[i], &b[j]),

C++学习笔记----6、内存管理(四)---- 通常的内存陷阱(1)

使用new/delete/new[]/delete[]处理动态内存以及底层内存操作是非常容易出错的。对于引起内存有关的问题还特别难以定位。每一个内存泄露与错误指针都有其细微差别。没有能够解决内存问题的银弹。我们就来谈一谈一些通常问题以及能够检测和解决的一些工具。 1、少分配了数据空间与越界内存访问         对于C风格的字符串来讲少分配了数据空间是一个常见的问题,当程序员

【流程图】流程图符号

1、常用符号 2、例子(胡乱画的)

有符号和无符号的转化

1.无符号转有符号 测试结果: 2.有符号转换为无符号数 测试结果: 其他

流程图符号速查:快速掌握流程图绘制要点

流程图是一种以图形化方式表示算法或过程的步骤和逻辑关系的图表,它通过使用一系列标准的符号和连接线来清晰地展示流程的顺序和决策点。这种表示方法不仅使得复杂的过程更加易于理解,而且也便于跟踪和优化。以下是对流程图的进一步扩写,包括其制作步骤、应用场景和一些实用技巧。流程图常常用来表示一些动态过程,通常会有一个“起点”, 可以有一个或多个终点,流程图可以直观、明确地表示动态过程从开始到结束的全部步骤,在

Hessian矩阵判定极值之MATLAB实现符号解

By WC 1.9 .2015 1.Hessian矩阵 其定义如下: 如果函数f在D区域内二阶连续可导,那么黑塞矩阵H(f) 在 D 内为对称矩阵。原因是:如果函数f连续,则二阶偏导数的求

【计算机组成原理】详细解读无符号整数的表示与运算

定点数的编码表示与运算 导读一、无符号整数1.1 无符号整型的取值范围1.2 数据在内存中的存储1.3 小结 二、无符号整数的运算2.1 无符号整数的加法2.2 无符号整数的减法2.3 小结 结语 导读 大家好,很高兴又和大家见面啦!!! 在上一篇内容中我们介绍了BCD码的相关内容: BCD码是用二进制编码的十进制数,通常用4位二进制数表示一位十进制数码;8421码是一种

C++字符串操作中的陷阱

休对故人思故国,且将新火试新茶。诗酒趁年华。                                                                             ——《望江南·超然台作》【宋】苏轼 目录 正文: 首先我们要明白出现问题的原因: 1. 缓冲区溢出 2. 错误的字符串声明方式 3. 缺乏对NULL指针的检查  解决方案: 下期预