当前位置: 首页 > 知识库问答 >
问题:

条件与运算符?

尉迟京
2023-03-14

GCC(4.8.2版)手册中规定了以下内容:

< code >-ftree-loop-if-convert-stores :< br >尝试同时if-convert包含内存写入的条件跳转。这种转换对于多线程程序来说是不安全的,因为它将有条件的内存写入转换为无条件的内存写入。举个例子,

   for (i = 0; i < N; i++)
      if (cond)
        A[i] = expr;

被转换为

   for (i = 0; i < N; i++)
       A[i] = cond ? expr : A[i];

可能产生数据竞争。

然而,我想知道使用运算符是否会提高性能if语句。

    < li >在第一段代码中,只有满足条件时,< code>A[i]才会设置为< code>expr。如果不满足,则跳过语句中的代码。 < li >在第二个示例中,< code>A[i]似乎与条件无关;该条件仅影响其设置的值。

使用运算符,我们也在进行检查;然而,在不满足条件的情况下,我们会增加一些开销。我错过了什么吗?

共有1个答案

宿镜
2023-03-14

说的是,条件跳跃被转换为有条件的移动指令 即cmove指令家族。它们提高了速度,因为它们不会像跳跃那样使处理器管道停止。

使用跳转指令时,你不知道要加载哪些指令,因此将使用预测并在管道中加载分支。如果预测是正确的,一切都很好,下一个指令已经在管道上执行。但是,在评估跳转后,如果预测错误,则管道中已有的所有以下指令都是无用的,因此必须释放管道,并加载正确的指令。现代处理器包含 16-30 个管道阶段,分支错误会严重降低性能。有条件的移动会绕过这一点,因为它们不会在程序流中插入分支。

但是cmobile总是写吗?

来自英特尔 x86 指令集参考:

CMOVcc指令检查EFLAGS寄存器[..]中一个或多个状态标志的状态,如果这些标志处于指定状态(或条件),则执行移动操作。[…]如果不满足条件,则不执行移动,并继续执行CMOVcc指令后面的指令。

编辑

在进一步研究gcc手册时,我感到困惑,因为据我所知,编译器不会优化将C代码转换为另一个C代码,而是使用内部数据结构,如控制流图,所以我真的不知道它们在示例中的含义。我想它们是指生成的新流的C等价物。我不确定这个优化是否是关于生成cmoves

编辑2

由于cmobile使用寄存器而不是内存进行操作,因此

if (cond)
  A[i] = expr

无法生成cmobile

然而,这

 A[i] = cond ? expr : A[i];

能。

假设我们在bx中有expr值。

load A[i] into ax
cmp // cond
cmove ax, bx
store ax into &A[i]

因此,为了使用cmove,您必须读取A[i]值,如果cond为false,则将其写回,这与if语句不同,但与三元运算符相同。

 类似资料:
  • Java 提供了一个特别的三元运算符(也叫三目运算符)经常用于取代某个类型的 if-then-else 语句。 条件运算符的符号表示为“?:”,使用该运算符时需要有三个操作数,因此称其为三目运算符。使用条件运算符的一般语法结构为: 其中,expression 是一个布尔表达式。当 expression 为真时,执行 statement1, 否则就执行 statement3。此三元运算符要求返回一个

  • 主要内容:RxJava 条件运算符 介绍,RxJava 条件运算符 示例RxJava 条件运算符 介绍 以下是用于 Observable 的条件运算符。 运算符 描述 All 评估发出的所有项目以满足给定标准。 Amb 仅在给定多个 Observable 的情况下从第一个 Observable 发出所有项目。 Contains 检查 Observable 是否发出特定项目。 DefaultIfEmpty 如果 Observable 不发出任何内容,则发出默认项。 Se

  • 条件运算符的格式为:A ? B : C。其中A是布尔类型,如果表达式A的执行结果为true,则执行B,并返回表达式B的执行结果,如果A的执行结果为false,则执行C,并返回表达式C的执行结果。例如${("a" > "b")? 4: 5}的执行结果为5。

  • C++ 运算符 Exp1 ? Exp2 : Exp3; 其中,Exp1、Exp2 和 Exp3 是表达式。请注意冒号的使用和位置。? : 表达式的值取决于 Exp1 的计算结果。如果 Exp1 为真,则计算 Exp2 的值,且 Exp2 的计算结果则为整个 ? : 表达式的值。如果 Exp1 为假,则计算 Exp3 的值,且 Exp3 的计算结果则为整个 ? : 表达式的值。 ? 被称为三元运

  • 问题内容: 如果我想实现一些可以通过两种方式实现的条件代码。那么哪种方式更好的是条件运算符?:或if..then..else ?? 问题答案: 这取决于。通常,您希望活动的主要流程在代码的结构中表示。如果算法的关键是变量已初始化,那么最好的解决方案是使用条件运算符: 如果决策是了解正在发生的事情的关键问题,那么您将首选。实际上,这意味着当两者都可行时,您将使用。关键是“合理” —如果您发现在子表达

  • 如果希望获得两个数中最大的一个,可以使用 if 语句,例如: 不过,C语言提供了一种更加简单的方法,叫做 条件运算符,语法格式为: 表达式1 ? 表达式2 : 表达式3 条件运算符是C语言中唯一的一个三目运算符,其求值规则为:如果表达式1的值为真,则以表达式2 的值作为整个条件表达式的值,否则以表达式3的值作为整个条件表达式的值。条件表达式通常用于赋值语句之中。 上面的 if else 语句等价于