sizeof是c语言关键字,功能是求指定数据类型在内存中的大小,单位:字节
int类型
-
int常量,变量
-
printf输出int值
%d,输出一个有符号的10进制整数,%u,代表输出一个无符号的10进制整数 -
printf输出八进制和十六进制
%x,代表输出16进制数,%X,用大写字母方式输出16进制数
%o代表输出八进制数 -
short,long,long long,unsigned int
short意思为短整数,在32位系统下是2个字节,16个比特
long意思为长整数,在32位的系统下,long都是4个字节的,在64位系统下,windows还是4个字节,unix下成了8个字节
int不管是32位系统下,还是64位系统下,不论是windows还是unix都是4个字节的
整数溢出
计算一个整数的时候超过整数能够容纳的最大单位后,整数会溢出,溢出的结果是高位舍弃
当一个小的整数赋值给大的整数,符号位不会丢失,会继承
大端对齐与小端对齐
对于arm,intel这种x86构架的复杂指令CPU,整数在内存中是倒着存放的,低地址放低位,高地址放高位,小端对齐
int x=0x12345678;
//12345678(16进制) int为4字节,一字节8位 12 34 56 78
//转为2进制=每4位对应8421
//(2进制) 0001 0010 0011 0100 0101 0110 0111 1000
//int x=0x12345678;
//// 0001 0010 0011 0100 0101 0110 0111 1000 原码
//// FA61 FA60 FA59 FA58
printf(“%#X”,&x);//&取首地址符 #显示几进制
但对于unix服务器的CPU,更多是采用大端对齐的方式存放整数
char类型
1.char常量,变量
char c;定义一个char变量
‘a’,char的常量
char的本质就是一个整数,一个只有1个字节大小的整数
2.printf输出char
%c意思是输出一个字符,而不是一个整数
3.不可打印char转义符
a,警报
退格
换行
回车
制表符
斜杠
’单引号
”双引号
?问号
4.char和unsigned char
char取值范围为-128到127
unsigned char为0-255
数据越界
char x=127+2;
printf(“%d”,x);
129
转为2进制 除余得到原码1000 0001(有符号)
反码=1111 1110
补码=1111 1111 输出-127
unsigned char x=255+10;
printf(“%d”,x);
265 = 256 128 64 32 16 8 4 2 1
= 1 0 0 0 0 1 0 0 1(2进制)
=1 0000 1001 (正数的原、反、补一致)
=9
浮点float,double类型
1.浮点常量,变量
float在32位系统下是4个字节,double在32位系统下是8个字节
小数的效率很低,避免使用,除非明确的要计算一个小数。
2.printf输出浮点数
%f,%lf
%f是输出一个float
float pi=3.14;
printf(%10f,pi);//%f %10f是以10个格子(位)显示 %0.2f是精确到小数后2位(可以四舍五入)
%lf输出一个double
3.类型限定
-
const
-
const是代表一个不能改变值的常量
-
-
volatile
-
代表变量是一个可能被CPU指令之外的地方改变的,编译器就不会针对这个变量去优化目标代码
-
-
register
-
变量在CPU寄存器里面,而不是在内存里面。但regist是建议型的指令,而不是命令型的指令
-
字符串格式化输出与输入
-
字符串在计算机内部的存储方式
字符串是内存中一段连续的char空间,以' '结尾
""(双引号)是c语言表达字符串的方式 -
printf函数,putchar函数
printf格式字符
字符 对应数据类型 含义
d int 接受整数值并将它表示为有符号的十进制整数
hd short int 短整数
hu unsigned short int 无符号短整数
o unsigned int 无符号8进制整数
u unsigned int 无符号10进制整数
x/X unsigned int 无符号16进制整数 x对应小写,X对应大写
f/lf float或double 单精度浮点数或双精度浮点数
e/E double 科学计数法表示的数,'e'的大小写表示输入时的大小写
c char 字符型,按照ASCII码转换成对应字符
s/S char* / wchar_t * 字符串,输出字符串中的字符直到空字符(' ')
p void* 以16进制形式输出指针
% % 输出一个百分号(%)
//printf的附加格式
字符 含义
l 附加在d,o,u,x前面,表示长整数
- 左对齐
m 数据的最小宽度
0 将输出的前面补上0,直到占满指定列宽为止(不可以搭配'-'使用)
N 宽度至少N位,不够以空格填充
putchar是显示一个字符的函数
-
scanf函数与getchar函数
scanf通过键盘读取用户输入,放入变量中,记得参数一定是变量的地址(&)
int a=0;
int b=0;
scanf("%d",&a);//一定要用&取变量的地址
scanf("%d",&b);//一定要用&取变量的地址//scanf安全性解决方法:1 将scanf改为scanf_s
2 #define _CRT_SECURE_NO_WARNTINGS
3 多字符集 dslgetchar得到用户键盘输入的字符
char x;
x=getchar();//得到的是ASCII字符编码表中的字符
printf("%d
",x);
printf("%c
",x); abcd
markdown ctrl+shift+(-+)放大缩小