Verilog中parameter与宏定义的区别

参数定义

parameter xx = yy; (有分号)

宏定义

`define xx yy   (无分号)

作用范围

parameter是局部的,只在其定义的模块内部起作用,而宏定义对同时编译的多个文件起作用。即使在某一个模块内部指定的宏定义,在编译过程中仍旧对多个文件起作用,直至遇到重新定义为止。

特别强调:状态机

状态机的参数用parameter定义,不推荐使用`define宏定义的方式,因为`define宏定义在编译时自动替换整个设计中所定义的宏,而parameter仅定义模块内部的参数,定义的参数不会与模块外的其他状态机混淆。
例如一个工程里面有两个module,各包含一个FSM,如果设计时都有IDLE 这一名称的状态,如果使用`define 宏定义就会混淆,如果使用parameter则不会造成任何不良影响。

你可能感兴趣的:(Verilog中parameter与宏定义的区别)