首页 > 代码库 > 跟尹成前辈学C/C++ 004
跟尹成前辈学C/C++ 004
转义字符
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
void main1()
{
char ch = getchar(); //获取一个字符
putchar(ch); //输出一个字符
system("pause");
}
C判断是0和非0,
java、php等只有0和1
\a响铃
0 48
A 65
a 97
进制要弄得非常清楚
内存如何存放数据和指令
同一个时间,内存空间里只能保存一份值
变量的内存机制
变量表管理所有的变量,不能引用未声明的变量
只能给变量赋值,变量在内存
a+1属于寄存器,不能赋值
_asm
{
}
插入汇编
变量的赋值都是通过cpu的寄存器完成
a=10 ,10存放在代码区(只读)的常量符号表
标识符:程序中用于表示常量、变量、函数的字符序列,只能由字母、数字、下划线组成
C语言大小写不同
遵循软件工程规范,一看就懂
VC函数名变量名支持中文,gcc只有字符串可以中文
C语言老版本的编译器,GCC如果没有开启C++11支持,vc2010之前的版本,变量必须在函数调用之前定义。
初始化,新老版本编译器,新编译器提示错误,老版本不提示垃圾数据
常量分析
const int a=100;
不能直接修改常量的数据
&取地址运算符
间接赋值修改常量
* (int*) (&a)=16; //不算真正意义的常量
// *根据地址取出内容, int*类型转化为非常量类型
#define a 99
//define不能加分号,加了就是一起替换
c语言能操作内存,不能操作寄存器
define算是真正意义的常量,不能直接修改,也不能间接修改
汇编语言既能操作内存,也可以操作寄存器
define意义明确,可以实现批量修改,不能取地址,因为它是存在寄存器里的
变量交换 时空分析
时空复杂度
int temp=a;
a=b;
b=temp;
评估时空复杂度,temp增加空间1,时间3次
int a=10;
int b=5;
a=a+b; //a=15,b=5
b=a-b; //b=10,a=15
a=a-b; //a=5,b=10
空间0,赋值三次,加三次,共6次
+,-,*,/会数据越界,最安全的做法是异或
异或
变量的数据类型
进制
0代表八进制
0x代表十六进制
printf("%d",num);
以十进制输出结果
查看内存时一般是十六进制
计算机存储数据
内存是存储数据的房间
1个字代表4个字节
数据的类型
面试中常见,理解不透彻会出现问题
%f实数打印
数据类型的差别
printf不会自动完成数据类型转换
float f1=10.9;
printf("%d",f1);
直接按照整数去读实数会出错
理解语法规则,逻辑严密
数据类型的差别:不同数据类型占据的空间不同,解析方式不同
sizeof
char 1字节
int 4字节
double 8字节
sizeof是关键字,不是函数
sizeof还可以求表达式
sizeof("123")占4个字节,因为字符串默认会有一个\0结束
sizeof("A") 占1个字节
符号的作用
有符号和无符号
整数的极限
#include<limits.h> //极限的头文件
void main()
{
int num_max=INT_MAX;
int num_min=INT_MIN;
printf("max=%d,min=%d",num_max,num_min);
getchar();
}
unsigned char chnum=0; 2^8=256 0~255
数据的计算必须在极限的范围内
第一位0代表正数,1代表负数
数据在内存的排列
电脑手机 低位在低字节,高位在高字节
unix 低位在高字节
%u无符号
补码
反码正数与原码一样
补码正数与原码一样
负数反码+1
计算机是以补码的方式存储的
跟尹成前辈学C/C++ 004