【FPGA】 在Verilog中,! 和 ~ 的区别

在Verilog中,! 和 ~ 都是用来表示逻辑非操作的,但它们在使用上有一些区别:
:
是Verilog中的按位取反操作符,用于执行按位的逻辑非操作。

复制代码
它适用于任何位宽的向量或单个位。  

例如,\~8'b1101_0101 会得到 8'b0010_1010。  

!:

! 是Verilog中的逻辑非操作符,但通常用于表示逻辑非操作,而不是按位操作。

它通常用于逻辑表达式中,而不是直接作用于位向量。

例如,!a 表示逻辑非操作,其中 a 是一个逻辑信号或表达式。

例子

复制代码
module test_operators;
    reg [7:0] a;
    reg b;

    initial begin
        a = 8'b1101_0101;
        b = 1'b1;

        // 使用 ~ 进行按位取反
        a = ~a; // a 现在是 8'b0010_1010

        // 使用 ! 进行逻辑非
        b = !b; // 如果 b 原来是 1,那么现在 b 是 0
    end
endmodule

注意事项

优先级:在Verilog中,~ 的优先级高于 !。这意味着在没有括号的情况下,~ 会先于 ! 被计算。

可读性:在某些情况下,使用 ! 可能会使代码更易于理解,尤其是当涉及到逻辑条件时。例如,if (!a) 通常比 if (~a) 更直观。

使用场景:尽管两者都可以用于逻辑非操作,但 ~ 更常用于按位操作,而 ! 更常用于逻辑表达式。

总结

~:按位取反,适用于位向量或单个位。

!:逻辑非,通常用于逻辑表达式。

理解这两种操作符的区别,可以帮助你更准确地编写和理解Verilog代码。

相关推荐
北城笑笑26 分钟前
FPGA 与 市场主流芯片分类详解:SoC/CPU/GPU/DPU 等芯片核心特性与工程应用
前端·单片机·fpga开发·fpga
R.X. NLOS1 小时前
ZYNQ 开发知识点记录:AXI Timer 硬件定时器与中断机制解密
fpga开发·fpga·axi定时器
北城笑笑1 小时前
FPGA 51,基于 ZYNQ 7Z010 的 FPGA 高速路由转发加速系统架构设计(Xilinx ZYNQ-MINI 7Z010 CLG400 -1)
前端·fpga开发·系统架构·fpga
学习永无止境@2 小时前
MATLAB中矩阵转置
算法·matlab·fpga开发·矩阵
fei_sun2 小时前
【Verilog】阻塞/非阻塞赋值
fpga开发
minglie12 小时前
正点原子zynq的RGB彩条实验
fpga开发
FPGA-ADDA3 小时前
第六篇:多速率信号处理——抽取、插值与半带滤波器
fpga开发·信号处理·软件无线电·rfsoc·47dr
ALINX技术博客3 小时前
【黑金云课堂】VMware Ubuntu 开发环境安装教程
linux·fpga开发·fpga
LCMICRO-133108477463 小时前
国产长芯微LDC4048完全P2P替代DAC128S085,是一款 8 通道、带输出放大器的数模转换器 (DAC)
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·数模转换器dac
雅斯驰3 小时前
逐周期限流+频率折返+热关断:TPS54360DDAR的全套保护机制解析
fpga开发