6、标识符的作用域规则

标识符的作用域规则

       标识符是模块、变量、端口、实例、函数、任务、块结构等对象的名称,用于唯一地标识该对象。一个标识符的作用域是指Verilog描述中,该标识可以被识别的范围,作用域规则定义了这个范围。

       Verilog可以在四种实体中定义标识符:即模块、任务、函数和有名块。每个实体定义的标识符的局部作用域从它的定义位置开始到相应实体结束。对于这四种实体,其标识符范围为:

  • Module – endmodule
  • Task – endtask
  • Function – endfunction
  • Begin:name - end

       标识符引用的两种方式:

①超前引用:定义前就可引用,模块、任务、函数和有名块的标识符在定义前就可使用,如模块定义前就实例化一个模块、定义前调用一个任务或函数、终止一个有名块等;

②非超前引用:定义后方可引用,如寄存器,线网等变量不能超前引用;因此通常在定义模块等实体的局部作用域的开始处定义它们。

       在一个作用域中不能定义相同标识符,即

①在同一个实体内定义两个相同名字的变量;(同一模块、任务、函数和有名块);

②变量名与任务有相同的名字。

       Verilog将所有标识符组织成树的结构,树的根节点是没有被实例化的模块名(即最高层模块)。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值