C语言的int 为什么最小值是-32768

Python015

C语言的int 为什么最小值是-32768,第1张

C语言中,int若是规定大小为两个字节,则其最小值就是-32768。

原因是:

两个字节是16位,规定第一位为符号位,则其能表示的数值范围是-2^15~2^15-1,即-32768~32767。但最小值为什么是-32768,为什么不是-32767呢?

原来人们发现若是在内存中直接存放数的原码,则0000 0000 0000 0000和1000 0000 0000 0000分别表示+0和-0,其值都是0,用两个值表示同一个值,这样太浪费空间了。

于是人们最后决定在内存中存放数的补码,这样+0和-0的存放形式就都是0000 0000 0000 0000了,但是同时也多出来一个1111 1111 1111 1111,它并不是任何一个数的补码,于是将其规定为-32768。

这样表示的话,正数最大值是32767,负数最小值是-32768。

从 0到 32767,用二进制是从:00000000到01111111 。

从-1到-32768,用二进制是从:11111111到10000000 。

扩展资料:

C语言的优点:

优点

1、简洁紧凑、灵活方便

C语言一共只有32个关键字,9种控制语句,程序书写形式自由,区分大小写。把高级语言的基本结构和语句与低级语言的实用性结合起来。C 语言可以像汇编语言一样对位、字节和地址进行操作,而这三者是计算机最基本的工作单元。

C语言的 Hello World 程序

2、运算符丰富

C语言的运算符包含的范围很广泛,共有34种运算符。C语言把括号、赋值、强制类型转换等都作为运算符处理。从而使C语言的运算类型极其丰富,表达式类型多样化。灵活使用各种运算符可以实现在其它高级语言中难以实现的运算。

3、数据类型丰富

C语言的数据类型有:整型、实型、字符型、数组类型、指针类型、结构体类型、共用体类型等。能用来实现各种复杂的数据结构的运算。并引入了指针概念,使程序效率更高。

4、表达方式灵活实用

C语言提供多种运算符和表达式值的方法,对问题的表达可通过多种途径获得,其程序设计更主动、灵活。它语法限制不太严格,程序设计自由度大,如对整型量与字符型数据及逻辑型数据可以通用等。

5、允许直接访问物理地址,对硬件进行操作

由于C语言允许直接访问物理地址,可以直接对硬件进行操作,因此它既具有高级语言的功能,又具有低级语言的许多功能,能够像汇编语言一样对位(bit)、字节和地址进行操作,而这三者是计算机最基本的工作单元,可用来写系统软件。

6、生成目标代码质量高,程序执行效率高

C语言描述问题比汇编语言迅速,工作量小、可读性好,易于调试、修改和移植,而代码质量与汇编语言相当。C语言一般只比汇编程序生成的目标代码效率低10%~20%。

7、可移植性好

C语言在不同机器上的C编译程序,86%的代码是公共的,所以C语言的编译程序便于移植。在一个环境上用C语言编写的程序,不改动或稍加改动,就可移植到另一个完全不同的环境中运行。

8、表达力强

C语言有丰富的数据结构和运算符。包含了各种数据结构,如整型、数组类型、指针类型和联合类型等,用来实现各种数据结构的运算。C语言的运算符有34种,范围很宽,灵活使用各种运算符可以实现难度极大的运算。

C语言能直接访问硬件的物理地址,能进行位(bit)操作。兼有高级语言和低级语言的许多优点。

它既可用来编写系统软件,又可用来开发应用软件,已成为一种通用程序设计语言。

另外C语言具有强大的图形功能,支持多种显示器和驱动器。且计算功能、逻辑判断功能强大。

参考资料来源:百度百科-C语言

算补码的方式:正数的补码是器本身;而负数的补码要取反加1,且符号位不变;-32768的补码算法:我们先算-32768的二进制数是1000000000000000(注意这里的最高位是符号位哦,之所以是这个数是因为溢出的原因);取反就是1111111111111111(最高位符号为不变的哦),再加1,得到1000000000000000(符号位还是不变的哦),注意了最高位是符号位哦。好了不知道你懂了没。