首页 > 代码库 > c语言编写经验逐步积累4

c语言编写经验逐步积累4

寥寥数笔,记录我的C语言盲点笔记,只为曾经经历过,亦有误,可交流。

 

1.逻辑表达式的使用
取值 = 表达式 ? 表达式1:表达式2;
比如x = y > z ? y:z

2."+,-"等逻辑运算符优先级大于移位,移位大于逻辑运算

3.
sizeof在编译时由编译器完成,对其传入的参数不做运算处理。
sizeof(i++);返回4;不会对实际的i进行操作
sizeof和strlen的区别是,后者是运算时执行。
返回遇到非NULL时的字符个数。
sizeof处理数组名时会统计分配的内存数,如a[12] = {};则sizeof(a) = 12;
如a [] = "aaa",则编译器是分配4内存空间存放数据,sizeof(a)= 4;

4.强制类型转换先于+,-,故指针类型变化后,自加操作会不同;

5.invalid combination of type specifiers
无效的类型进行组合。引起的原因主要是头文件多种数据类型define和typedef引起了错误。
typedef是一个类型的重定义 不是宏的值的重定义 只能用于类型的替换
,主要在编译阶段,需要带有分号

define是宏定义,主要在预处理阶段,不太适合做类型转换,结尾分号会被带入宏替换
比如先定义
#define Uint8 unsigned char 
typedef xdc_Uint8 Uint8;这就进行了宏替换为:
typedef xdc_unsigned char Uint8;从而导致了类型结合无效的现象。故define宏是预处理的替换,而typedef是做到数据类型的真正转换与定义。
宏最好不要进行typedef的转换!!!。
数据类型在多处定义时,注意不要出现上述情况

6.printf输出%号,需要使用printf("%%\n");来输出

7.逻辑或与运算或要切记:
|和||,以及&和&&的使用。

8.取非!和~的运算优先级》 + -;

9 strcpy是将源地址开始到\0结束的字节数复制到目的地址。
strlen统计的从源地址到遇到\0前的字节数,不算如\0

10.某一位置1 A |= (1 << 5);
某一位置0 A &=  ~(1 << 5);
某一位取反 A ^= (1 << 5); 与1异或取反。

11. union进行赋值时需要使用a.b操作

12、0x%08x,输出16进制数要达到8位,不然在前面补0

14.栈帧包括另一帧需要的函数参数,返回的pc地址以及当前帧的ebp.

15. 结构体对齐
struct test
{
char x1;
short x2;
float x3;
char x4;
};
由于编译器默认情况下会对这个struct作自然边界(有人说“自然对界”我觉得边界更顺口)对齐,结 构的第一个成员x1,其偏移地址为0,占据了第1个字节。第二个成员x2为short类型,其起始地址必须2字节对界,因此,编译器在x2和x1之间填充 了一个空字节。结构的第三个成员x3和第四个成员x4恰好落在其自然边界地址上,在它们前面不需要额外的填充字节。在test结构中,成员x3要求4字节 对界,是该结构所有成员中要求的最大边界单元,因而test结构的自然对界条件为4字节,编译器在成员x4后面填充了3个空字节。整个结构所占据空间为 12字节。

16. 
memset(),是将n个字节都设置为传入的一个字节如memset(a, 0, 100);
memcpy(dst, src, n);将src开始的n个字节copy到目的上去。

17.多进程引用的动态链接库中的全局变量问题 
由于不同进程间是独立的,有自己的text和data,而全局位于数据段,故不会存在竞争的现象。

18.struct的一种结构体数组申明与定义的方法。
static struct {   char *name;
    int offset;  } _reg_list[] = {};
 


a