一元约简运算符,双目运算符只用一目“&”“|”只有一侧有操作数

  • 今天在看师兄的代码的时候发现了如下的代码
always @ (posedge clk or negedge rst_n)
    begin
	    if (!rst_n)
		    data <= 14'b0;
    	else if (state == CNV)
	    if ((|bit_cnt[4:1]) && (~&bit_cnt[4:1]) && time_cnt[0])	
	    	data <= {data[12:0],miso};
	    else
			data <= data;
    end

        对第二个if else循环中的&、|有疑问,明明这两个在verilog中都是双目运算符,为什么在这里只有一侧有操作数,后来在其他博主那里看到,原来这样的用法叫做“一元约简运算符”。

1.一元约简运算符解释

        这种运算符和位运算符的符号是一模一样的,但是仍然能够正常阅读而不产生歧义,一元约简运算符是将后面的多位操作数依次进行位运算。

2.例子

|4'b1010    //1 | 0 | 1 | 0 即为1.

|4'b0010    //0 | 0 | 1 | 0 即为1.

|4'b1000    //1 | 0 | 0 | 0 即为1.


&4'b1010    //1 & 0 & 1 & 0 即为0.

&4'b0010    //0 & 0 & 1 & 0 即为0.

&4'b1000    //1 & 0 & 0 & 0 即为0.

3.图一代码解释

        |bit_cnt[4:1] 代表从bit_cnt的第4位开始,依次进行或运算至第1位,得出最终结果。

        ~&bit_cnt[4:1] 代表从bit_cnt的第4位开始,依次进行与运算至第1位,然后再进行取反运算得出最终结果。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值