首页/指令库/CZERO-NEZ
CZERO.NEZ

RISC-V CZERO.NEZ 指令详解

指令手册R-type

条件置零:若rs2非零则rd=0,否则rd=rs1

指令语法

czero.nez rd, rs1, rs2
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数寄存器。
源寄存器 rs2:第二个操作数寄存器。
Zicond条件操作

指令行为说明

czero.nez 是 Zicond 条件置零指令。若 rs2 不等于 0,rd 写 0;否则 rd 写 rs1。

快速理解与检索要点

czero.nez 是 Zicond 条件置零指令。若 rs2 不等于 0,rd 写 0;否则 rd 写 rs1。

可用于构造无分支条件选择序列,但架构语义本身只是条件写 0。
rd 对 rs1 和 rs2 都有语法依赖,官方手册专门定义了这些依赖关系。

常见使用场景

位操作与掩码

结合 «czero.nez x10, x11, x12 ; x10 = (x12 != 0) ? 0 : x11» 等实际代码理解该场景。

分支与跳转

结合 «czero.nez x10, x11, x12 ; x10 = (x12 != 0) ? 0 : x11» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 R-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

它只在两个结果之间选择:0 或 rs1;不会执行分支,也不会访问内存。
条件只测试 rs2 是否为零,不比较 rs1 与 rs2。

常见问题

czero.nez 是条件跳转吗?

不是。它不会改变 PC,只根据 rs2 是否为零选择写 0 或 rs1。

czero.nez 会比较两个寄存器大小吗?

不会。条件只看 rs2 是否为零。