C语言字符常量数字转化为整形,2 C语言 常量,进制,类型限定 输入输出 运算符 类型转换...

常量:#define const 字符串常量

1 8 10 16 进制转换

sizeof关键字

变量 int folat char

类型限定 const volatile register

输入输出 printf scanf

运算符 = + - *  / % += -= *= /= %= ++ -- , 运算符优先级

代码块{}

类型转换

1C语言中的数据类型

1.1常量

常量就是在程序中不可变化的量,常量是不可被赋值的。

1.1.1#define

#define的本质就是简单的文本替换

通过#define定义的常量,在C语言里面一般叫宏定义

1.1.2const

const定义一个变量,但是这个变量的值只能在定义的时候赋予,之后就不可以修改。

对于const类型的变量,一定要在定义的时候给变量赋初值,不然定义之后就无法赋值了。

1.2字符串常量

在C语言当中“”引用的字符串都是字符串常量,常量一旦定义也是不可以被修改的。

1.3位,字节,字

1.3.1位

计算机内部都是二进制的,一个二进制的位,就叫做一个bit,就是一位

1.3.2二进制

逢二加1,在二进制表达数的时候是只有0和1,而没有2这个数的

二进制最大表示的数,就是2几次幂

对于8位的CPU来讲,最大表达的数是2的8次幂

1.3.3十进制

逢10加1,只有从0到9的数,没有10这个数,

860a593314c6dd08d4cd8e9cf8584656.png

1.3.4八进制

从0到7,逢8加1

在C语言中八进制是数字前面加0

1.3.5十六进制

0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,10

逢16加1,

在C语言当中表达一个十六进制数的方式,数字前面加0x前缀

1.3.6字节

8个bit为代表一个字节

1.4sizeof关键字

sizeof与size_t类型

sizeof是计算数据在内存当中占多大空间的,单位字节

由于sizeof永远返回的是一个大于等于0的整数,所以如果用int来表示sizeof的返回值就不合适,size_t一般就是一个无符号的整数.

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

179f2f9eb97d75391e3573873ee812f1.png

1.6int类型

1.6.1int常量,变量

一个int型数据占据4个字节的内存大小,在16位操作系统下,int是2个字节,在32和64位操作系统下,int是4个字节。

int a;//代表在内存当中开辟一个4个字节大小的空间

a = 10;//代表4个字节的空间内容是常量10

小端对齐和大端对齐

高地址放高位,底地址放低位---小端对齐

高地址放低位,底地址放高位—大端对齐

对于大型unixCPU都是按照大端对齐方式处理int,

但对于x86构架CPU,还有ARM,是小端对齐的

430bde4f0960dda0726c456ccd7f2600.png

919887efd8079764263863ac747fa551.png

1.6.2printf输出int值

int a = 0x100;//十六进制

printf(“%d”,a);%d的意思是按照10进制打印一个整数

%x

%X,输出十六进制的时候是用大写的ABCDEF还是小写的abcdef,

1.6.3printf输出八进制和十六进制

%o

1.6.4short,long,long long,unsigned int

在32位系统下:

short = 2个字节

long和int一样,是4字节

long long是8个字节

在64位操作系统下

int,4个字节

long在大多数64位系统下8个字节

unsigned int//无符号整数

unsigned long//无符号的长整数

unsigned short//无符号短整数

9l,9L,9ll,9LL,9u,9ull,9ULL

1.6.5整数溢出

当把一个大的整数赋值给小的整数,叫溢出。

int I = 0x12345678

short a = I;

当一个int赋值给short,会将高位抛弃,

1.7char类型

1.7.1char常量,变量

char是字符型,代表一个字节的内存

char在内存当中,有符号最大7f,

无符号,最大ff

unsigned char

char的本质就是一个字节,一个BYTE

1.7.2printf输出char

%c

1.7.3不可打印char转义符

\a,警报

\b退格

\n换行

\r回车

\t制表符

\\斜杠

\’单引号

\”双引号

\?问号

1.7.4char和unsigned char

char取值范围为-128到127

unsigned char为0-255

1.8浮点float,double,longdouble类型

1.8.1浮点常量,变量

float f = 2.5;

double f1 = 3.1415926

1.8.2printf输出浮点数

%f,%Lf

1.9类型限定

1.9.1const

const限定一个变量的值不可以改变

1.9.2volatile

告诉编译器不要自作聪明的给我优化代码,把我的变量优化的寄存器里面计算,只要是volatile类型变量,每一步都需要从内存当中读取。

036a66db55abd0240401c644b9d9f31d.png

1.9.3register

register告诉编译器,这个变量只是用寄存器就好,提高效率,所以说register只是一个建议,而不是必须的结果。

2字符串格式化输出和输入

2.1字符串在计算机内部的存储方式

字符串是内存中一段连续的char空间,以’\0’结尾

字符串就是0结尾的连续char的内存

2.2printf函数,putchar函数

printf格式字符字符对应数据类型含义

dint接受整数值并将它表示为有符号的整数

hdShort int短整数

huUnsigned short int无符号短整数

ounsigned int无符号8进制整数

uunsigned int无符号10进制

x / Xunsigned int无符号整数,x对应的是abcdef,X对应的是ABCDEF

ffloat或double

e / Edouble表示的数,此处"e"的大小写代表在输出时用的“e”的大小写

cchar型。可以把输入的数字按照相应转换为对应的字符

s / Schar * / wchar_t *。输出字符串中的字符直至字符串中的空字符(字符串以'\0‘结尾,这个'\0'即空字符)

pvoid *以16进制形式输出

%%输出一个百分号

printf附加格式字符含义

l附加在d,u,x,o前面,表示长整数

-左对齐

m(代表一个整数)数据最小宽度

0将输出的前面补上0

spacer.gif直到占满指定列宽为止

spacer.gif不可以搭配使用

spacer.gif-

spacer.gif

spacer.gif

N(代表一个整数)宽度至少为n位

spacer.gif不够以空格填充

spacer.gif

printf是打印一个字符串

putchar是打印一个字符

2.3scanf函数与getchar函数

3运算符表达式和语句

3.1基本运算符

3.1.1=

数据对象:泛指数据在内存的存储区域

左值:表示可以被更改的数据对象

右值:能赋给左值的量

3.1.2+

3.1.3–

3.1.4*

3.1.5/

3.1.6%

取模,取余数

3.1.7+=

int a = 10;

a = a + 5;

可以简写成a +=5;

3.1.8-=

a = a – 5;a -= 5;

3.1.9*=

a = a * 5;a *= 5;

3.1.10/=

3.1.11%=

3.1.12++

3.1.13--

3.1.14逗号运算符

int I = 6 + 5, 3 + 2

逗号表达式先求逗号左边的值,然后求右边的值,整个语句的值是逗号右边的值。

3.1.15运算符优先级优先级运算符结合性

1++(后缀),--(后缀),()(调用函数),{}(语句块),.,->从左到右

2++(前缀),--(前缀),+(前缀),-(前缀),!(前缀),~(前缀),sizeof,*(取指针值),&(取地址),(type)(类型转化)从右到左

3*,/,%从左到右

4+,-从左到右

5<< >>从左到右

6< > <= >=从左到右

7== !=从左到右

8&从左到右

9^从左到右

10|从左到右

11&&从左到右

12||从左到右

13?从右到左

14=,*=,%=,+=,-=,<<=,>>=,&=,|=,^=从右到左

15,(逗号运算符)从左到右

3.2复合语句

{}代码块

3.3类型转化

doubled =10.2;

inta =d;//隐式转换

inta1 =3;

inta2 =2;

doublemid = (double)a1 / (double)a2;//显示的强转

printf("mid = %f\n", mid);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值