1.越界

没有给一个变量申请足够大的内存,而copy大于该内存的数据

int main()
{
char a;
char *str=&a;
strcpy(str,"hello");
printf(str);
return 0;
}

2.字节对齐问题

typedef struct{
    char a;
    short b;
    int c;
}struct_size_test1;

typedef struct{
    char a;
    int b;
    short c;
}struct_size_test2;

printf("struct_size_test %d,%d",sizeof(struct_size_test1),sizeof(struct_size_test2));

输出:struct_size_test 8,12
因为字节对齐,最大类型是4个字节,所以struct_size_test1中char和short可以放在一块,所以是8个字节,但是struct_size_test2 中char之后是int类型,不能再放了,只能再申请一块所以是12字节

3.野指针问题(最普遍)

wap( int* p1,int* p2 )
{
int *p;
*p = *p1;
*p1 = *p2;
*p2 = *p;
}

指针p初始化的时候没有明确指向NULL,只时候赋值的话可能会导致其他内存被改变,从而程序崩溃

4.对绝对地址操作

(unsigned int*)0x100000 = 1234;

这是对决定地址进行赋值操作

(void (*)())0x100000;
*((void (*)())0x100000)();

这是将决定地址强制转化为函数指针,然后执行这个函数指针

5带参宏和带参函数的区别

C常见问题_赋值

6 a++和++a的区别

a++是先执行表达式再执行自加
++a是先执行自加再执行表达式