31天C语言进阶——1,数据存储:整数

前置:VS调试技巧

(1),有一段待调试的代码。

#include<stdio.h>
int main() {
    
    
	int a = 10;
	float b = 10.0f;

	return 0;
}

(2),有一个断点。

点击那个地方就行。

在这里插入图片描述
(3),进入调试。

在这里插入图片描述
效果:运行,但是没显示。

在这里插入图片描述
(4),调出内存界面。

调试——窗口——内存——随便选一个。

在这里插入图片描述

效果:

在这里插入图片描述
(5),查看某个变量的值。

在地址里面输入&xxx,回车。xxx为变量名。

在这里插入图片描述
案例中,a的值为10,内存为0a,十六进。a比9大1,就是10啦。

1,1和-1的内存

用于调试的代码:

#include<stdio.h>
int main() {
    
    
	int a = 1;
	int b = -1;

	return 0;
}

内存结果:1

在这里插入图片描述

内存结果:-1

在这里插入图片描述
不用怀疑,就是左上角的四个字节。

2,有符号,无符号

数值用最高的一个二进制位代表符号。0正,1负。

unsigned修饰的类型,没有符号位。

比如unsigned int,四个字节,都是数值内容。
而int,最高位代表符号,只有31位是数值。

无符号数最大值:2的n方-1
有符号数最大值:2的n-1方-1

3,原码,反码,补码

无符号数:三码相同。

有符号正数:三码相同。

有符号负数:有讲究。
原码:数值的二进制表示。
反码:符号不变,其他位翻转。1变0,0变1。
补码:反码的结果加1。

举例:-1,一字节。
原码:1 000 0001
反码:1 111 1110
补码:1 111 1111

,4,整数以补码存储

1的三码相同,所以内存中为01 00 00 00
字节顺序是倒过来的。

-1的补码为1111 1111
转十六进,就是 ff 啦。

5,补码,正数加法

直接算加法就行。

1+1=2

0000 0001
0000 0001
=》
0000 0010

6,补码,正数减法

转为正数和负数,直接算加法。

-1
原:1000 0001
反:1111 1110
补:1111 1111

1±1=0

0000 0001 + 1111 1111

符号位:1
数值:000 0000,溢出。

溢出的时候,符号位翻转,结果:
0000 0000

7,大端,小端

存数据有两种策略:

  1. 从左往右放。1就是00 00 00 01
  2. 从右往左放。1就是01 00 00 00

用指针判断当前的策略:

int isSmall() {
    
    
	int test = 1;
	char* p = (char*)&test;
	if (*p == 1) {
    
    
		//大端
		return 0;
	}
	else {
    
    
		//小端
		return 1;
	}
}

简化一下:

int isBig() {
    
    
	int test = 1;
	return *(char*)&test;
}

番外:实现修改金钱

把一个地址值改成ff。

代码:

#include<stdio.h>
int main() {
    
    
	int money = 10;
	printf("金币数:%d\n", money);

	printf("金币数:%d\n",money);
	return 0;
}

找到money的内存地址:

在这里插入图片描述
对着数值,右键编辑值。

在这里插入图片描述
效果:

在这里插入图片描述
最终显示:

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_37284843/article/details/124418902