硅芯思见:task和function的区别

在使用Verilog进行设计的过程中,使用task和function在同一个module中多次调用,充分提高了代码的复用性,有效增强设计的可维护性和复用性,可以避免不同模块间代码复制导致的不必要的错误。本文主要探讨task和function的使用以及两者之间的异同点。

1 task

 定义不能出现在过程性语句快中,但是必须在“module-end”结构中。

格式一:

 格式二:

 task可以没有或者有一个或多个参数,值通过参数传入和传出task。输入输出在任务开始处声明,且输入与输出信号的排列顺序决定了task被调用时传递参数的顺序。在使用task时需要注意以下几点:

  • task一般在过程性语句中被调用,且调用语句中的输入必须与task定义中的一致,输出亦然,参数传递的顺序保持一致;
  • task参数是按照值传递方式进行传递(不是引用),所以在被调用的task执行的过程中,如果该task外部输入参数发生变化是不会影响正在执行的task;
  • 因为task在过程性语句中定义,所以task在调用时传递的参数都是变量类型(reg、integer、real等);
  • 定义task的module中的变量对于task是可见的,即task可引用其所在module中定义的变量,但是这种引用全局变量的做法极度不推荐;
  • task在默认情况下是static,即当多个并行进程调用同一个task时将会有可能导致程序异常(后续进行示例详述);
  • task参数列表中的可以没有或者有一个或多个参数;
  • 使用task注意区分static和automatic型task使用的方法;
  • 在task中可以调用任意多个task和function;

【示例】

 2 function

定义不能出现在过程性语句快中,但是必须在“module-end”结构中。

格式一:

 格式二:

 function同task一样,都可在过程性语句中调用,与task不同的是function还可以在连续赋值语句中使用,function至少有一个输入,且其实现的过程中不能包含延时、时序控制等,即调用后立即执行。function中不能调用task,但是可以调用其他的function。在使用function注意以下几点:

  • 10
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

硅芯思见

你的鼓励是我创作的最大源泉

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值