#ifndef
时间: 2024-02-12 18:07:13 浏览: 45
`#ifndef`是预处理器的一个指令,用于防止头文件被重复包含。
当一个头文件被重复包含时,编译器可能会产生一些意外的错误,比如重复定义的变量或函数等。为了避免这种情况,我们可以在头文件的开头加上以下指令:
```
#ifndef HEADER_FILE_NAME_H
#define HEADER_FILE_NAME_H
// 在这里写头文件的内容
#endif
```
其中,`HEADER_FILE_NAME_H`是一个自定义的宏名称,可以是任何合法的标识符。当编译器第一次遇到这个指令时,会判断`HEADER_FILE_NAME_H`这个宏是否已经被定义过了,如果没有定义过,则会将`#define`和`#endif`之间的内容编译进来;如果已经定义过了,则会直接跳过这段内容。
这样,当同一个头文件被多次包含时,只会编译一次,避免了重复定义的问题。
相关问题
C头文件声明时 #ifndef __与#ifndef_的区别
在C语言中,头文件通常使用预处理指令 `#ifndef` 来避免重复包含,避免造成重复定义的错误。而在 `#ifndef` 后面通常会跟着宏定义的名称,用于标识该头文件是否已经被包含过了。在这种情况下,通常有两种方式来定义宏:
1. `#ifndef __MYHEADER_H__`,这里的 `__MYHEADER_H__` 是一个标识符,可以是任何合法的标识符。这种方式的好处是能够避免与其他头文件的宏定义冲突。
2. `#ifndef MYHEADER_H`,这里的 `MYHEADER_H` 是一个不带下划线的标识符。这种方式可能会与其他头文件的宏定义冲突,因为在C语言中,下划线开头的标识符通常被保留作为编译器或库的内部使用。
总的来说,两种方式都可以用于头文件的宏定义,但建议使用第一种方式,以避免可能的冲突。
E:\qtpro\workspace\PanTool_UPPER\worker.h:1: error: unterminated #ifndef In file included from ..\PanTool_UPPER\worker.cpp:2: ..\PanTool_UPPER\worker.h:1: error: unterminated #ifndef #ifndef WORKER_H
这个错误通常是由于在头文件的 #ifndef 预处理指令中缺少对应的 #endif 导致的。请确保在 worker.h 文件的末尾添加 #endif 以正确结束 #ifndef 和 #endif 之间的条件编译区块。以下是修复后的代码示例:
```cpp
// worker.h
#ifndef WORKER_H
#define WORKER_H
#include <QObject>
#include <QSerialPort>
#include <QThread>
class Worker : public QObject
{
Q_OBJECT
public:
explicit Worker(QObject *parent = nullptr);
public slots:
// 开始工作的槽函数
void startWork();
// 停止工作的槽函数
void stopWork();
signals:
// 接收到数据时发出的信号
void dataReceived(const QByteArray& data);
private:
QSerialPort *port; // 串口对象指针
};
#endif // WORKER_H
```
请确保在 `worker.h` 的末尾添加了 `#endif`,以解决这个错误。
阅读全文