你可能与我一样苦恼为什么别人写的代码每个文件中都用`ifndef 、define 和endif宏来定义,不知道为什么需要这几句话。下面将详述这几个的用法。
目的
使用 ifndef 、define 和endif的目的:为了防止同一个文件在编译时被重复编译,引起多重定义的问题。
如下:在文件开头和结尾定义
`ifndef APB_MASTER_DRIVER_SV
`define APB_MASTER_DRIVER_SV
class apb_master_driver extends uvm_driver#(apb_transfer);
...
endclass
`endif
作用
- ifndef 的含义:即 “if not defined”,也就是说,当文件编译到这一行,如果这个文件还没有被编译过,也就是首次编译,就会执行后续的 `define xxx这句话,把后续的代码定义一次。反之,则不会再重复编译。
- ifdef 的含义:即"if defined",与 ifndef 的作用相反,如果已经编译过,那么则继续执行后面的代码。
- enif 的含义:出现 ifndef 或者 ifdef 作为开头,程序块的末尾就需要有 endif 作为结束的标识。
逻辑块有的形式包括:
1️⃣ 如果尚未被编译,则执行后续程序块;反之则不执行。
注:为了避免重复编译的问题,建议将每个文件都加上ifndef 、define 和endif
`ifndef xxx
`define xxx
程序块
`endif
2️⃣ 如果已经编译过,则执行程序1;反之则执行程序2.
`ifdef xxx
程序1
`else
程序2
`endif

ifndef、define和endif宏主要用于防止C/C++代码文件在编译过程中被重复编译,避免多重定义问题。这些宏定义确保每个文件仅编译一次,提高编译效率并保持代码一致性。文章详细解释了ifndef检查宏是否已定义,define定义宏,以及endif作为代码块结束的逻辑,并给出了使用示例。

844

被折叠的 条评论
为什么被折叠?



