C++中#ifndef XXX_H #difine XXX_H解析及dllexport、dllimport用法示例

在学习C++的过程中,我们经常发现在头文件前部有一些标识符定义,比如:

//示例1:

#ifdef CREATEDELL_API_DU
#else                                                                            
#define CREATEDELL_API_DU _declspec(dllimport) 


//示例2:

#ifndef DLL_API
#define DLL_API __declspec(dllexport)
#endif
#else
#define DLL_API __declspec(dllimport)
#endif // !DLL_API

//导出函数,若要导出函数,必须出现在调用约定关键字的左边(最左边)
DLL_API int add(int a,int b);
 
//导出类,要导出类中的所有公共数据成员和成员函数,必须出现在类名的左边(挨着)
class DLL_API cls
{
public:
   int add(int a,int b);
}


//示例3:

#ifndef _MAIN_H_ 
#define _MAIN_H_

//示例4:

#ifndef LX_DLL_CLASS_EXPORTS
    #define LX_DLL_CLASS __declspec(dllexport)
#else
    #define LX_DLL_CLASS __declspec(dllimport)
#endif

这样几段代码的意思是 如果没有定义函数CREATEDELL_API_DU、DLL_API、头文件main.h、LX_DLL_CLASS 的别名,就定义它,作用是如果有其他文件多次调用这个头文件,那么为了防止重复定义,加入判断语句,只有第一次会进行定义,当第一个定义后,其他的调用定义会忽略。

看到这里有一个疑问,就是为什么要加这么一段,不加不就不重复了吗?

在大型文件系统中,可能有多个cpp包含一个头文件,添上这一句后就可以防止头文件被多次编译。

#ifndef xxx

#define xxx

//头文件正文

#endif

头文件中这一段是一段完整的内容,无论改文件被包含多少次,只有xxx在第一次定义时,头文件正文才会编译,其他时候不会。头文件可以使用多段这样的内容,各有各的标识符,在程序中可以提前定义标识符,从而指定某些段头文件不编译。
 

你可能感兴趣的:(C++)