1.在一个头文件(.h)文件中定义变量,不初始化
- 该变量是全局变量
- 该变量的作用域为包含该头文件的源文件
- 如下图,在user.h中定义但不赋值一个变量flag,那么所有包含user.h这个头文件的源文件都能使用flag。
//--------------user.h----------------
#ifndef _USER_H
#define _USER_H
int flag;
void dem_fun(void);
#endif // !_USER_H
//-------------main.c------------------
#include <stdlib.h>
#include "user.h"
int main()
{
flag = 0;
printf("%d\n\r",flag);
}
2.在一个头文件(.h)文件中定义变量且初始化
- 该变量是全局变量
- 该变量的作用域是使用extern声明但不包含该头文件的源文件
-
如下,在user.h中定义且不赋值一个变量:int flag=0,那么在main.c这个源文件中通过extern 声明就可以使用flag。
-
如果包含了user.h这个头文件,编译器会报错:C_Project_Valuables\Debug\C_Project_Valuables.exe : fatal error LNK1169: 找到一个或多个多重定义的符号
-
这是因为引用该头文件时,等同于在源文件中定义了这个全局变量
//--------------user.h----------------
#ifndef _USER_H
#define _USER_H
int flag=0;
void dem_fun(void);
#endif // !_USER_H
//-------------main.c------------------
#include <stdlib.h>
extern flag;
int main()
{
flag = 1;
printf("%d\n\r",flag);
}
3.在头文件(.h)文件中定义static和const变量但不赋值
- 该变量是全局变量
- 该变量的作用域是引用了该头文件的源文件内部
- 如下图,main.c源文件通过引用user.h头文件,相当于在main.c源文件中重新定义了
- const int flag;
- static int boost;
- 但由于作用域在当前源文件,编译器不会警告
//--------------user.h----------------
#ifndef _USER_H
#define _USER_H
const int flag;
static int boost;
void dem_fun(void);
#endif // !_USER_H
//-------------main.c------------------
#include <stdlib.h>
#include <user.h>
extern flag; //可要可不要
int main()
{
flag = 1;
printf("%d\n\r",flag);
}
结论
- 请在头文件中声明函数和变量
- 在源文件中定义函数和变量
- 带赋值的必定是定义
- extern是声明
- 变量的定义即声明