你可能与我一样苦恼为什么别人写的代码每个文件中都用`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