1.register int a; 定义寄存器变量,让编译器把a放到cpu的寄存器中,加快此变量的存取速度,但是也有可能不会被放入cpu寄存器中
2.const int a = 3; 伪常量a,具有只读属性。当被定义为局部变量时,a = 10是错误的,变量定义后不能被重新赋值;但是可以通过int *p = (int *)&a; *p = 10,指针方式修改变量的值。
当被定义为全局变量时,通过指针方式也不能修改变量的值。
3.case 0…100:
4.goto 函数内部跳转
Longjmp 函数与函数之间跳转
5.Restrict int *p; 使编译器优化指针变量p,此关键字仅针对指针变量
6.Void *p; 指针指向任意类型数据
7.#pragma pack(num) 调整编译器数据对齐方式
例如:#pragma pack(1) 按1字节对齐
#pragma pack(2) 按2字节对齐
编译器默认为按4字节对齐
8.要点:typedef的使用
要点:memcpy函数的使用
9.进程空间是独立的,所以每个进程都有自己独立的4G空间。
10.宏函数
#define swp(a, b) {a = a ^ b; b = a ^ b; a = a ^ b;}
为了避免调用时运算优先级导致的一些运算错误,一般需要将变量全部加上括号
即:#define swp(a, b) {(a) = (a) ^ (b); (b) =(a) ^ (b); (a) = (a) ^ (b);}
注意:在宏函数中实现的代码不应该含有循环语句,代码尽可能短
交换x, y的值,函数调用
swp(x, y);
11.return 返回多个数据,采用将数据压缩到一个int型变
量中
12.return 返回多个数据,也可以通过返回结构体对象
13.数据区的数据,即全局变量,静态变量在定义时,系统自动初始化为0
栈区数据,即局部变量在定义时,初始值为随机值
bzero(str, n) 将从str连续n字节的内存空间清0
不论str指向的空间是int,char还是结构体类型的,该函数只会将str地址开始的n字节内存空间清0
14.内联函数,即在普通函数前面加inline关键字
inline int add(int a, int b)
{
return a+b;
}
注意:尽量不要在内联函数中写入循环语句。
编译时与宏函数相似,会把函数体替换到每次调用的地方
15.int i = 0;
printf(“%d %d”, i, i++);
函数传参时,先将参数中的表达式进行计算,然后再依次将实参传递给形参
16.可变参数编程
17.如下所示,自己编写的通过return返回多个值的宏。
cmpr(a, a0, a1,a2, a3) a0,a1,a2,a3为4个字节的待返回数据,若实际需要返回数据小于4个字节,则只需在无效返回值的位置上填写0即可,a0,a1,a2,a3实际将被放在int型变量a的从低到高4个字节内存中。
decmpr(a, num, ax) num表示需要提取的返回值标号,范围是0-3,0为int型返回值a的最低位,即压缩前的a0;ax将存储提取的返回值。
#include <stdio.h>
#define cmpr(a, a0, a1, a2, a3) {(a) = ((a) = 0, (((((((a) | (a3)) << 8) | (a2)) << 8) | (a1)) << 8) | (a0));}
#define decmpr(a, num, ax) {(ax) = ((a) >> ((num) * 8)) & 0xff;}
int test(void);
int main (int argc, char *argv[])
{
int a, i, dat[4];
a = test();
for(i = 0; i < 4; i++)
{
decmpr(a, i, dat[i]);
printf("%d ", dat[i]);
}
printf("\n");
return 0;
}
int test(void)
{
char a0 = 10, a1 = 56, a2 = 23, a3 = 34;
int a;
cmpr(a, a0, a1, 0, 0);
// 压缩成4个字节
return a;
}