extern关键字会提升变量或者函数的逼格,使得它们可以跨文件被访问。
首先,你得在cpp文件里面实现这些全局变量和全局函数,这是最基本的,然后只需要在需要用到这些变量和函数的文件里声明一下,用extern修饰声明,这样弄完之后就可以随意使用这些全局变量和全局函数了。
别的文件里写一堆的extern声明显得特别不专业,也显得代码十分臃肿,有没有好的做法呢?
我们一般把所有的全局变量和全局函数都放在一个.cpp文件里面,然后用一个同名的**.h文件包含所有的函数和变量的声明。用法的示例如下:
/*Demo.h*/
#ifndef _DEMO_H_
#define _DEMO_H_
extern int a;
extern int b;
int add(int a, int b);
#endif
/**
//下面的写法也可以
#pragma once
extern int a; //这是定义了啊
extern int b;
*/
/*Demo.cpp*/
#include "Demo.h"
int a = 10;
int b = 20;
int add(int l, int r)
{
return l + r;
}
/*main.cpp*/
#include "Demo.h"
#include <iostream>
using namespace std;
void main()
{
cout << "a = " << a << ", b = " << b << endl;
int c = add(1, 2);
printf("c = 1 + 2 = %d \n", c);
system("pause");
}
这样处理之后只需要到用到的地方加入#include”Demo.h”一句即可,这么干方便了这些变量和全局函数的管理。
注意定义和声明的区别,extern int a = 10;属于定义了。如果在.h文件里这样写肯定是编译不通过的,因为存在重定义。#include”Demo.h”这一句是单纯的代码替换,在Demo.cpp和main.cpp里替换之后你自然发现全局变量被定义了两次,肯定会报错。一句话,声明可以拷贝n次,但是定义只能定义一次。
在A.cpp中使用B.cpp中的全局变量,需要extern声明。extern关键字的作用是告诉编译器,在某个cpp文件中,存在这么一个函数/全局变量。函数的声明类似于:extern int sum(int, int);函数的声明语句中,关键字extern可以省略,因为全局函数默认是extern类型的。
- 如果你将前面的Demo.cpp改为Demo.c的话,编译器会告诉你说找不到变量和函数是无法解析的外部符号,怎么办呢?
之所以会出现这样的原因,是因为c++编译器和c编译器差异性的问题,C++语言在编译的时候为了解决函数的多态问题,会将函数名和参数联合起来生成一个中间的函数名称,而C语言则不会,因此会造成链接时找不到对应函数的情况,我们是在main.cpp文件里包含了Demo.h也就是在main.cpp里面声明了这么一些变量和函数(代入即可),main.cpp里面的声明会被c++编译器成处理中间的名称,而Demo.c里面的实现会被c编译器处理,两者处理的差异性,导致问题多多。总之处理之后.c文件的实现和.cpp里面的声明不一致了,这也是导致找不到的原因,这个时候就必须用extren “C”了,告诉c++编译器,请保持我的名称,不要给我生成用于链接的中间函数名。
声明
/*Demo.h*/
#ifndef _DEMO_H_
#define _DEMO_H_
#ifdef __cplusplus
extern "C" {
#endif
extern int a;
extern int b;
int add(int a, int b);
#ifdef __cplusplus
}
#endif
定义
注意:**__cplusplus,前面是两个_
/*Demo.c*/
//#include "Demo.h"
#include <stdio.h>
int a = 10;
int b = 20;
int add(int l, int r)
{
#ifndef __cplusplus
printf("这是一个c程序!\n");
#endif // !_cplusplus
#ifdef __cplusplus
printf("这是一个c++程序!\n");
#endif // !_cplusplus
return l + r;
}
使用
/*main.cpp*/
#include "Demo.h"
#include <iostream>
using namespace std;
void main()
{
#ifdef __cplusplus
cout << "这是一个c++程序" << endl;
#endif
#ifndef __cplusplus
cout << "这是一个c程序" << endl;
#endif
cout << "a = " << a << ", b = " << b << endl;
int c = add(1, 2);
printf("c = 1 + 2 = %d \n", c);
system("pause");
}