时间:2022-09-22 10:40:37 | 栏目:C代码 | 点击:次
下面看一段 enum 的使用代码吧:
#include<stdio.h> enum { ARRAY_SIZE = 10 }; enum Color { RED = 0x00FF0000, GREEN = 0x0000FF00, BLUE = 0x000000FF }; void PrintColor(enum Color c) { switch (c) { case RED: printf("Color: RED (0x%08x)\n", c); break; case GREEN: printf("color: GREEN (0x%08X)\n", c); break; case BLUE: printf("Color: BLUE (0x%08X)\n", c); break; } } void InitArray(int array[]) { int i = 0; for (i = 0; i < ARRAY_SIZE; i++) { array[i] = i + 1; } } void PrintArray(int array[]) { int i = 0; for (i = 0; i < ARRAY_SIZE; i++) { printf("%d\n", array[i]); } } int main() { enum Color c = GREEN; int array[ARRAY_SIZE] = {0}; PrintColor(c); InitArray(array); PrintArray(array); return 0; }
下面为输出结果:
这段程序说明enum 中定义的值是C语言中真正意义上的常量。
sizeof 可以采用以下的用法:
sizeof 是 C 语言的内置关键字而不是函数
下面看一段 sizeof 的本质的代码:
#include<stdio.h> int f() { printf("Autumn Ze"); return 0; } int main() { int var = 0; int size = sizeof(var++); printf("var = %d, size = %d\n", var, size); size = sizeof(f()); printf("size = %d\n", size); return 0; }
下面为输出结果:
为什么 var 不等于 1 呢?这是因为在编译过程中所有的 sizeof 将被具体的数值所替换,var++ 这条语句根本得不到执行。同样,f() 函数也不会得到执行,所以不会输出 Autumn Ze,只会输出返回值类型 int 的字节数。
typedef 用于给一个已经存在的数据类型重命名
typedef 本质上不能产生新的类型
typedef 重命名的类型:
用法:typedef type new_name;
下面看一段 typedef 使用的代码:
#include<stdio.h> typedef int Int32; struct _tag_point { int x; int y; }; typedef struct _tag_point Point; typedef struct { int length; int array[]; }SoftArray; typedef struct _tag_list_node ListNode; struct _tag_list_node { ListNode* next; }; int main() { Int32 i = -100; //unsigned Int32 ii = 0; Point p; SoftArray* sa = NULL; ListNode* node = NULL; return 0; }
这段代码主要就是说明typedef 重命名的类型可以在 typedef 语句之后定义,不能被 unsigned 和 signed 修饰。