if 下与 或执行与否

在写代码的时候,有个形如: Qlist<int> list的链表,由于对它为空以及非空但是满足某条件的情形都需要新增子项,所以考虑到用下面的用法:

int count = list.size;

if(count == 0 || (count >0 && list.at(0) == xx)){

.....

}

但是有个疑问,if会执行到后面的list.at(0)吗,如果执行到这儿,岂不是段错误。

抱着试试的心态,测试了下,发现居然没问题。似乎是说明编译器不执行后面的代码。

为了进一步验证,我执行下面的语句。

int a=0;
    if(a==0 ||(a++ ==1))
    }
    qDebug()<<"a:"<<a;

结果打印a:0;说明确实没有执行后面的a++;那么应该可以做这么一个判断:

与、或表达式前面语句满足条件(第一个表达式:或表达式为true,与表达式为false)就不往后执行了

  int a=0,b=0;
    if(a==1 &&(a++ ==1)){
 
    }
    qDebug()<<"a:"<<a;

打印结果:a:1;的确验证我的猜测。所以我开始的写法是安全的。

### Vue 中 `if`、`else` 和 `else-if` 的执行顺序解析 在 Vue.js 中,条件渲染通过 `v-if`、`v-else-if` 和 `v-else` 指令实现。这些指令用于控制 DOM 元素的显示与否,基于表达式的真假值决定是否渲染对应的模板部分。 当使用多个条件分支时,Vue 会按照声明的顺序依次评估每个条件: - **`v-if`**: 首先被评估。如果其绑定的表达式返回真,则渲染该元素;否则跳过此元素并继续向下检查其他条件。 - **`v-else-if`**: 只有在其前一个兄弟节点上的 `v-if` 者 `v-else-if` 表达式不成立的情况下才会被考虑。可以连续使用多个 `v-else-if` 来表示多层逻辑判断[^1]。 - **`v-else`**: 不需要任何表达式,默认作为最后的选择项,在前面所有的 `v-if`/`v-else-if` 均未满足时生效[^2]。 需要注意的是,为了确保正确的优先级关系,带有 `v-else` `v-else-if` 的元素必须紧跟在带 `v-if` 另一个 `v-else-if` 的元素之后,并且它们之间不能有任何非空白文本其他 HTML 标签隔开[^3]。 此外,由于编译阶段会对这些结构化标签进行优化处理,因此即使页面上存在大量嵌套者复杂的条件组合也不会影响最终性能表现[^4]。 ```html <div id="example"> <!-- 正确 --> <p v-if="type === 'A'">Type A</p> <p v-else-if="type === 'B'">Type B</p> <p v-else>Not A/B</p> <!-- 错误 --> <span></span> <p v-if="type === 'C'">Type C</p> <p v-else>Not C</p> </div> ``` #### 注意事项 为了避免潜在错误,建议保持简洁明了的条件链路设计,减少不必要的复杂度。对于非常深的嵌套情况,可能更适合重构为更清晰的数据模型采用计算属性来简化视图逻辑[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值