Java: |(或运算) 与 多选判断
今天需要在程序中做一个多选判断,突然想起以前经常遇到的 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: |(或运算) 与 多选判断的更多相关文章
- Java位运算总结:位运算用途广泛《转》
前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...
- Java位运算原理及使用讲解
前言日常开发中位运算不是很常用,但是巧妙的使用位运算可以大量减少运行开销,优化算法.举个例子,翻转操作比较常见,比如初始值为1,操作一次变为0,再操作一次变为1.可能的做法是使用三木运算符,判断原始值 ...
- Java位运算总结:位运算用途广泛
前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...
- Java 位运算超全面总结
1.原码.反码.补码 关于原码.反码.补码的相关知识作者不打算在这里长篇大论,相关知识已有别的大佬总结很好了,还请老铁自行 Google,不过有篇知乎回答是作者学编程以来见过对相关知识最通俗易懂,生动 ...
- 我们必须要了解的Java位运算(不仅限于Java)
本文原创地址为 https://www.cnblogs.com/zh94/p/16195373.html 原创声明:作者:陈咬金. 博客地址:https://www.cnblogs.com/zh94/ ...
- Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range
在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...
- js,java,浮点数运算错误及应对方法
js,java浮点数运算错误及应对方法 一,浮点数为什么会有运算错误 IEEE 754 标准规定了计算机程序设计环境中的二进制和十进制的浮点数自述的交换.算术格式以及方法. 现有存储介质都是2进制.2 ...
- java中字符串的非空判断
问题如下:在java 中 字符串为null 如何判断String str;if(str==null) ??str.equal("null") ?? 答:我觉得应该搞清楚字符串对象和 ...
- 收藏的一段关于java大数运算的代码
收藏的一段关于java大数运算的代码: package study_02.number; import java.math.BigDecimal; import java.math.BigIntege ...
随机推荐
- Ubuntu apt-get提示被锁住
执行 apt-get 时提示资源被锁住 E: Could not get lock /var/lib/dpkg/lock - open (11: Resource temporarily unavai ...
- LINUX内核分析第八周总结:进程的切换和系统的一般执行过程
一.进程调度与进程切换 1.不同的进程有不同的调度需求 第一种分类: I/O密集型(I/O-bound) 频繁的进行I/O 通常会花费很多时间等待I/O操作的完成 CPU密集型(CPU-bound) ...
- Junit4测试用例
一.题目简介 测试一元一次方程的求解 二.源码的github链接 https://github.com/liujing1994/test1 三.所设计的模块测试用例.测试结果截图 一元一次方程测试 ...
- Oracle系列(二): Oracle表的外键查询
在执行数据库删除操作时,外键关联是令我们最烦的一个东西,有了外键关联,就不允许随意删除数据,那么怎知道这个外键关联度的外键属于那个表? select * from user_cons_columns ...
- What’s for Beta
经过和Travis与Zhongqiu讨论,我们希望我们发布的Beta版本会支持如下内容: Naïve long-term plan UI (Useable) Naïve long-term plan ...
- css - 背景图片充满整个屏幕
body { /* 加载背景图 */ background: url("../static/images/index/backImg.jpg") no-repeat; /* 背景图 ...
- opencv学习笔记(一)
摘要:最近要做一个和图像处理有联系的项目,从此走上了学习opencv的道路. 灰度图:2维矩阵 彩色图:3维矩阵 ps:目前大部分设备都是用无符号 8 位整数(类型为 CV_8U)表示像素亮度 Mat ...
- Expanded encryption and decryption signature algorithm SM2 & SM3
Expanded encryption and decryption signature algorithm supports multiple signature digest algorithms ...
- ESXi安装时遇到不识别的硬件的处理
1. 部门新购置了一台inspur 四路 NF8480M4的服务器. 上架之后发现ESXi的标准安装盘无法安装. 找不到磁盘安装介质. 2. 处理办法, 找浪潮专家服务,报上序列号,要上相关的一些软件 ...
- ios微信浏览器中video视频播放问题
微信ios只支持几种特定的视频格式,一般使用mp4格式的视频(腾讯官方就是用的这种视频格式)