• c#中(&&,||)与(&,|)的区别和应用


    对于(&&,||),运算的对象是逻辑值,也就是True/False
    &&相当与中文的并且,||相当于中文的或者 。(叫做逻辑运算符又叫短路运算符)
    运算结果只有下列四种情况。
    True  && True  = True    (左边为true,再验证右边也为true,返回结果true)假如这是一个查询条件,则执行。
    True  && False = False   (左边为true,再验证右边为false,返回结果false)假如这是一个查询条件,不执行。
    False && True  = False   (左边为false,发生短路现象。右边不再执行,直接返回false).........同样不执行。
    False && False = False   (同上)
    True  || True  = True    (左边为true,发生短路现象,右边不执行,直接返回true).......执行
    True  || False = True    (左边为true,发生短路现象,右边不执行,直接返回true).......执行
    False || True  = True    (左边为false,再验证右边为true,返回结果true)............执行
    False || False = False   (左边为false,再验证右边也为false,返回结果false).......不执行
    对于(&,|),运算的对象是位,也就是1/0,叫做位运算符
    理解:0为false,1为true(通用:0表示假,所有非零的数表示真。   ######方便记忆:0,什么都没有骗人的,则为假)
    运算结果只有下列四种情况。
    1 & 1 = 1
    1 & 0 = 0
    0 & 1 = 0
    0 & 0 = 0
    
    1 | 1 = 1
    1 | 0 = 1
    0 | 1 = 1
    0 | 0 = 0
    &&和&对于他们各自的运算对象来说,结果是一样的。

    下面用一段代码来说明||在实际代码中的运用

    var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 &&
                                                        (!param.TaxTypeId.HasValue || f.TaxTypeId == param.TaxTypeId)).ToList();

     当传入的参数中TaxTypeId==null时,param.TaxTypeId.HasValue为true,发生短路现象,右边不执行,返回结果true。

    则实际执行代码:var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 ).ToList();

     当传入的参数中TaxTypeId==123时,param.TaxTypeId.HasValue为false,执行右边的代码,即f.TaxTypeId == 123, 

    则实际执行代码:var data = svc.DeclarationHeads.Include("TaxType").Where(f => f.CorporationCode == param.CorporationCode && f.FlowSign == 2 &&
                                                                      f.TaxTypeId == 123 ).ToList();

    适用范围:当我们再勾选条件进行查询或者操纵数据库时,可以任意选择条件个数进行查询,而只需调用同一个方法。(即一个服务完成多重条件的查询)减少冗余代码。

  • 相关阅读:
    Vue.Draggable/SortableJS 的排序功能,在VUE中的使用
    vue项目中安装使用echarts
    CSS3美化有序列表
    Git 设置
    javascript 使用btoa和atob来进行Base64转码和解码
    vue 裁剪图片,插件Cropper的使用
    PHPEXCEL xls模板导入,及格式自定义:合并单元格、加粗、居中等操作
    HTML5的 input:file上传 以及 类型控制
    phpexcel 导出到xls文件的时候出现乱码解决
    Python+Selenium+PIL+Tesseract真正自动识别验证码进行一键登录
  • 原文地址:https://www.cnblogs.com/likui-bookHouse/p/7479369.html
Copyright © 2020-2023  润新知