今天需要在程序中做一个多选判断,突然想起以前经常遇到的 x |= y | z; 这样的,我也明白这个是多选的用意,但为什么能达到我们希望的多选操作,我还真的没去研究过。

今天早上,百度了一下,搜索到了两篇文章:

1) 这个是用C写的,道理都一样。摘自:http://blog.csdn.net/arduousbonze/article/details/1619096

三者的性质
异或运算:相同为0,不同为1
与运算:两者为1时为1,有0为0
或运算:有1为1

定义如下宏:(观察其特点)

#define FLAG_DUPLICATE   0x01   //展开二进制00000001 
#define FLAG_VISIBLE     0x02   //展开二进制00000010 
#define FLAG_CANSELECT   0x04   //展开二进制00000100 
#define FLAG_LABELED     0x08   //展开二进制00001000 
#define FLAG_BACKGROUND  0x10   //展开二进制00100000  
#define FLAG_SHOWOUTLINE 0x20   //展开二进制01000000 
#define FLAG_SHOWATEAGLE 0x40   //展开二进制10000000

(注:在C/C++中八进制以0开头,如0123(区别十进制的123);十六进制以0x开头,如0x40)
这样设置宏目的是为了能够应用位运算的性质来判断复选框的状态

假设用 int nStatus;来存储复选框的结果,可以这样做:

1.若某一个复选框选中则:nStatus=nStatus|FLAG_DUPLICATE;(其他类似)

2.那么如果取消了一个复选框呢?应该这样做:
  int mask=0xffffffff^FLAG_DUPLICATE;//(把FLAG_DUPLICATE中为"1"的那一位置为0,其它位都为1)
  nStatus=nStatus&mask;(其他类似)

3.如何判断某一复选框是否被选中呢?这样做:
  if(nStatus&FLAG_DUPLICATE==FLAG_DUPLICATE)
      cout<<"选中"<<endl;
  else
      cout<<"未选中"<<endl;

例子:

//取消复选框 
void __fastcall LayerInfo::SetVisible(bool bVisible)
{
    if(bVisible)
        m_nStatus=m_nStatus|FLAG_VISIBLE;
    else
{
        int mask = 0xffffffff^FLAG_VISIBLE;
        m_nStatus=m_nStatus&mask;
    }
    layer->Visible= bVisible;
}

//判断某一复选框是否被选中
if(m_nStatus&FLAG_SHOWOUTLINE==FLAG_SHOWOUTLINE)
    layer->Symbol->Outline=true;
else
    layer->Symbol->Outline=false; 还有一篇: http://blog.csdn.net/battlehawk/article/details/5271327 另外我写了一个简单的测试|(或运算)的例子,根据输出的结果,看出规律来了吧:

System.out.println(-1 | -1);   //输出 -1
System.out.println(-1 | 0);   //输出 -1
System.out.println(-1 | 1);   //输出 -1

System.out.println(0 | 0);   //输出 0
System.out.println(0 | 1);   //输出 1
System.out.println(0 | 2);   //输出 2

2011-12-31

Java: |(或运算) 与 多选判断的更多相关文章

  1. Java位运算总结:位运算用途广泛《转》

    前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...

  2. Java位运算原理及使用讲解

    前言日常开发中位运算不是很常用,但是巧妙的使用位运算可以大量减少运行开销,优化算法.举个例子,翻转操作比较常见,比如初始值为1,操作一次变为0,再操作一次变为1.可能的做法是使用三木运算符,判断原始值 ...

  3. Java位运算总结:位运算用途广泛

    前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...

  4. Java 位运算超全面总结

    1.原码.反码.补码 关于原码.反码.补码的相关知识作者不打算在这里长篇大论,相关知识已有别的大佬总结很好了,还请老铁自行 Google,不过有篇知乎回答是作者学编程以来见过对相关知识最通俗易懂,生动 ...

  5. 我们必须要了解的Java位运算(不仅限于Java)

    本文原创地址为 https://www.cnblogs.com/zh94/p/16195373.html 原创声明:作者:陈咬金. 博客地址:https://www.cnblogs.com/zh94/ ...

  6. Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range

    在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...

  7. js,java,浮点数运算错误及应对方法

    js,java浮点数运算错误及应对方法 一,浮点数为什么会有运算错误 IEEE 754 标准规定了计算机程序设计环境中的二进制和十进制的浮点数自述的交换.算术格式以及方法. 现有存储介质都是2进制.2 ...

  8. java中字符串的非空判断

    问题如下:在java 中 字符串为null 如何判断String str;if(str==null) ??str.equal("null") ?? 答:我觉得应该搞清楚字符串对象和 ...

  9. 收藏的一段关于java大数运算的代码

    收藏的一段关于java大数运算的代码: package study_02.number; import java.math.BigDecimal; import java.math.BigIntege ...

随机推荐

  1. 从源码的角度看 React JS 中批量更新 State 的策略(上)

    在之前的文章「深入理解 React JS 中的 setState」与 「从源码的角度再看 React JS 中的 setState」 中,我们分别看到了 React JS 中 setState 的异步 ...

  2. SpringBoot笔记--FastJson

    FastJson配置 ObjectId class ObjectIdSerializer : ObjectSerializer { override fun write(serializer: JSO ...

  3. SQL多表查询总结

    前言 连接查询包括合并.内连接.外连接和交叉连接,如果涉及多表查询,了解这些连接的特点很重要.只有真正了解它们之间的区别,才能正确使用. 一.Union UNION 操作符用于合并两个或多个 SELE ...

  4. socket.io框架

    socket.io框架 一.问题背景 目前公司在互联网产品上需要程序与前端部分要进行一个实时交互,在进行一定程度上的选型后,决定使用socket.io框架进行一个实践,算是公司的一个新的 尝试,也算是 ...

  5. tftp服务、串口工具minicom

    linux下安装tftp服务 参考这位仁兄的经验 确实百度上很多关于配置tftp服务的方法,但是这篇文章的介绍真的是很精简,对于一个刚接触纯linux环境的小白来说是很舒服的一件事. 首先是安装tft ...

  6. oracle mysql gbk varchar varchar2

    http://www.cnblogs.com/kxdblog/p/4042331.html https://wenku.baidu.com/view/97524e0f844769eae009ed80. ...

  7. 第七周PSP 新折线图和饼图 个人时间管理

    1.PSP DATE START-TIME END-TIME EVENT           DELTA TYPE 4.18 15.36 16.10 读构建执法 走神5min         29mi ...

  8. python箱型图

    #-*- coding: utf-8 -*- import pandas as pd catering_sale = '../data/catering_sale.xls' #餐饮数据 data = ...

  9. 【转载】JAVA消息服务JMS规范及原理详解

    转载:https://www.cnblogs.com/molao-doing/articles/6557305.html 作者: moyun- 一.简介 JMS即Java消息服务(Java Messa ...

  10. BZOJ4998星球联盟——LCT+并查集(LCT动态维护边双连通分量)

    题目描述 在遥远的S星系中一共有N个星球,编号为1…N.其中的一些星球决定组成联盟,以方便相互间的交流.但是,组成 联盟的首要条件就是交通条件.初始时,在这N个星球间有M条太空隧道.每条太空隧道连接两 ...