【sv】for循环+fork-join_none结构的坑

本文探讨了System Verilog中的fork-join_none结构在与for循环结合使用时可能出现的问题。作者通过实例揭示了由于执行顺序和变量共享导致的意外结果,并提出了解决方案——使用automatic关键字确保变量的独立性。文章强调了理解和掌握好这种结构的重要性,以避免在实际工作中遇到问题。
摘要由CSDN通过智能技术生成

来源| 杰瑞IC验证(ID:Jerry_IC)

1. 回忆下fork-join_none

fork-join_none相信大家应该熟悉了,新来的朋友可以回顾下jerry之前的文章,就是之前jerry提到的那个“暴脾气”的哥们,他不会去等别人,直接会着急做自己的事情。

前文回顾(点击查看):fork-join挺好用的了,fork-join_any、fork-join_none有什么用?

回顾下那篇文章中我们举的一个例子,这个暴脾气可以这么用:

fork

     aa( );       

     aa( );

     aa( );

    ……

     aa( );

     aa( );

join

如上代码,我们想要并行的执行100个 aa( )这个函数进程。通过fork-join要写到手软,用这个暴脾气,几句话就搞定:

for(int i=0; i<100; i++)

fork

     aa( );       

join_none

但是,今天jerry告诉各位初学者,这个暴脾气有不好驾驭的那一面的哦,弄不好就很容易翻车!!

2. fork-join_none翻车现场

什么情况下容易翻车呢?

大家仔细看看上面的例子,并行运行的aa( ),都是一样的内容,放在for循环中,却并没有使用for循环的循环因子 i 啊~

有人说,这有什么关系吗?

好的,来,看看jerry今天准备的代码,逼出它的邪恶面!

我们还是通过暴脾气fork-join_none

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值