2.c语言中数据类型

c语言中数据类型

1.1、C语言中的关键字

C的关键字共有32个

  • 数据类型关键字(12个) char,short,int,long,float,double unsigned,signed,struct,union,enum,void

  • 控制语句关键字(12个) if,else,switch,case,default for,do,while,break,continue,goto,return

  • 存储类型关键字(5个) auto,extren,register,static,const

  • 其他关键字(3个) sizeof,typedef,volatile

1.2、数据类型

数据类型的作用:编译器预算对象(变量)分配的内存空间大小

基本类型: 整形(int,short,long),字符型(char),实形/浮点型(float,double)

数据类型: 构造类型: 数组类型,结构类型(struct),联合类型(union),枚举类型(enum)

指针类型:(char *,int *, int **等)

1.3 、常量

  • 常量

    • 在程序运行过程中,其值不能被改变的量

    • 常量一般出现在表达式或赋值语句中

  • 整形常量:100,200,-100,0

  • 实形常量:3.14,0.125,-3.66456

  • 字符型常量:'a','b','c','d','e'

  • 字符串常量:"Hello World","大家很帅"

1.4、变量

  • 变量

    • 在程序运行过程中,其值可以被改变

    • 变量在使用前必须先定义,定义变量必须有相应的数据类型

  • 标识符命名规则:

    • 标识符不能是关键字

    • 标识符只能由字母,数字,下划线组成

    • 第一个字符必须为字母或者下划线

    • 标识符中字母区分大小写

  • 变量的特点

    • 变量在编译时为其分配相应的内存空间

    • 可以通过其名字和地址访问相应内存

  • 声明和定义的区别

    • 声明变量不需要建立存储空间.如:extern int a;

    • 定义变量需要建立存储空间,如:int b;

#include <stdio.h>

int main(){
   //extern关键字只做声明,不能做定义,后面还会学习,这里先了解
   //声明一个变量a,a在这里没有建立存储空间
   extern int a;
   a=10;
printf("%b\n",a);//没有空间,就不可以赋值,所以这里运行时会报错
   
   
   int b=10; //定义一个变量b,b的类型为int,b赋值为10
   printf("%b\n",b);//这里就会正常的显示一个10出来
   
   return 0;
}

从广义的角度来讲声明中包含着定义,即定义是声明的一个特例,所以并非所以的声明都是定义

  • int b 它既是声明,同时又是定义

  • 对于extern int b来讲它只是声明不是定义

一般情况下,把建立存储空间的声明称之为'定义',而把不需要建立存储空间的声明称之为'声明'.

1.5、使用示例

#define 与const

#include <stdio.h>
#define MAX 100
/*
1.#开头的语句是预处理语句,无需分号结束
2.定义一个宏定义标识符MAX,它代表100,MAX它是常量
3.宏定义以后的代码都可以使用MAX
4.在后面出现的MAX,预处理都会替换为100
*/

int main(){
   
   
   printf("%d\n,MAX");//宏定义以后的代码都可以直接使用MAX
   
   MAX = 120;         //不注释会报错
   printf("%d\n,MAX");
   
   //const 是一个关键字,作用是修饰一个变量只读(先做了解)
   const int b=10086;
   printf("%d\n",b);
     
   b = 10;          //不注释会报错
   printf("%d\n",b);//不注释会报错
   
   return 0;
}

1.6、计算机中的计量单位

计算机中最小的储存单位是 字节 (Byte)

计算机中最小的单位是 (bit)

1 字节 == 8

(为什么一个字节是8位。

因为计算机语言是美国人创造的,二进制0000 0000 到0111 1111转换成十进制是128个,他们的字符也刚好是128个。(这个就是ASCII(美国信息交换标准代码))用这二进制的八位来表示各种规定的信息比较方便。所以他们就用二进制的这八位代表一个字节!)

2、进制

二进制,八进制,十进制,十六进制

进制也就是进位制,是人们规定的一种进位方法,对于任何一种进制---X进制,就表示某一位置上的数运算时逢X进一位,十进制逢十进一,十六进制是逢十六进一,二进制是逢二进一,以此类推,X进制就是逢X进一.

十进制             二进制             八进制             十六进制
 0    0000      0 0
 1 0001  1 1
 2 0010  2     2
 3    0011  3         3
 4    0100  4 4
 5    0101  5     5
 6 0110  6 6
 7 0111  7 7
 8 1000  10 8
 9 1001  11 9
 10 1010  12 a
 11 1011  13 b
 12 1100  14 c
 13 1101  15 d
 14 1110  16 e
 15 1111  17 f
 16  1 0000  20     10
  • 二进制,位,字节与字

    我们习惯于十进制的数:10,12等

    一个位只能表示0,或者1两种状态,简称bit,一个位是一个bit

    一个字节位8个二进制,称为8位,简称BYTE,8个bit是一个字节

    一个字(汉字)为2个字节,简称WORD

    两个字为双字,简称DWORD

  • 八进制 八进制以8为基数的进制系统,c语言当中用0表示八进制,比如:0666

  • 十六进制 十六进16为基数的进制系统,c语言当中用0x/0X表示十六进制,比如:0x66f/0X66f

//进制的输出方式
#include <stdio.h>

int main(){
   
   int a=10;//什么都不写默认是十进制数据
   int b=010;//数字前面加个0表示八进数据
   int c=0x10;//数字前面加个0x表示十六进制数据
   
   printf("%d\n",a);//%d表示按照十进制数据输出显示
   printf("%o\n",b);//%o表示按照八进制数据输出显示
   printf("%x\n",c);//%x表示按照十六进制数据输出显示
   return 0;
}

十进制与其他进制转换可以利用短除法取余,例如:

13 转换成 二进制 13/2=6%1,6/2=3%0,3/2=1%1,1/2=0%1,那么它的二进制就是1101

600 转换成 八进制 600/8=16%0,75/8=9%3,9/8=1%1,1/8=0%1,那么它的八进制就是1130

171 转换成 十六进制 171/16=10%11,10/16=0%10,那么它的十六进制就是AB/ab

windows系统中有计算器可以转换进制。

 

3、计算机内存数值存储方式

计算机中的有符号数有三种表示方法,即原码反码和补码。三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位(即后 7 位),三种表示方法各不相同 。在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理;同时,加法和减法也可以统一处理。(源自百度百科)

原码

将最高位作为符号位(0代表正,1代表负),其余各位代表数值本身绝对值

    +7的原码是 0000 0111
   -7的原码是 1000 0111
   +0的原码是 0000 0000
   -0的原码是 1000 0000

反码

  • 一个数如果为正,那么反码和原码相同

  • 一个数如果为负,那么符号位为1,其他各位与原码相反

    +7的反码 0000 0111
   -7的反码 1111 1000
   +0的反码 0000 0000
   -0的反码 1111 1111    

补码

原码和反码都不利于计算机运算,如:原码表示的7和-7相加,还需要判断符号位

正数:原码,反码,补码都相同

负数:最高位为1,其余各位原码取反,最后对整个数+1

    +7的补码 0000 0111
   -7的补码 1111 1001
   +0的补码 0000 0000
   -0的补码 1 0000 0000 //计算机只能识别八位,所以前面的一位溢出不计。

计算机中的加法是利用补码来进行的,输出是用回原码,例:

15-10

将15与-10转换为二进制

根据正数:原码反码补码一致。负数:原码转反码除符号位不变,其他与原先的0与1互换,补码为反码加1得到

15 -10

原码:0000 1111 1000 1010

反码:0000 1111 1111 0101

补码:0000 1111 1111 0110

将补码相加等于 0000 0101

正数的原码与补码一致

装换为10进制为 5

-15+10

一样转换二进制

-15 10

原码:1000 1111 0000 1010

反码:1111 0000 0000 1010

补码:1111 0001 0000 1010

将补码相加等于 11111011

补码逆推反码,减一得 11111010

反码逆推原码,除符号位不变0与1互换得 10000101

转换为10进制为 -5

 

posted @ 2020-10-17 21:27  onedust  阅读(260)  评论(0)    收藏  举报