两段代码:
//global.c
#define GLOBAL_VARIABLES_HERE
#include "type.h"
#include "const.h"
#include "protect.h"
#include "global.h"
//global.h
# ifdef GLOBAL_VARIABLES_HERE
# undef EXTERN
# define EXTERN
# endif
EXTERN int disp_pos;
EXTERN t_8 gdt_ptr[6]; // 0~15:Limit 16~47:Base
EXTERN DESCRIPTOR gdt[GDT_SIZE];
EXTERN t_8 idt_ptr[6]; // 0~15:Limit 16~47:Base
EXTERN GATE idt[IDT_SIZE];
在预编译后,编译器对global.c进行了一个关键的处理:即使extern被定义成空值,这时global.h中的EXTERN不起作用,从而为全局变量开辟了内存空间.此内存空间只在global.c中被开辟,若为变量开辟两次空间,编译会出错.
在其他.c文件对global.h引用后,因为没有#define GLOBAL_VARIABLES_HERE这句宏定义,所以EXTERN起作用,此时,其他.c文件对全局变量进行引用,这时extern关键字起全局变量的作用。