/*【位运算符】
运算符: 运算 范例 说明 <<: 左移 3<<2=12--->3*2*2=12
>>: 右移 3>>2=1---->3/2=1
>>>: 无符号右移 3>>>2=1--->3/2=1
&: 与运算 6 & 3=2
|: 或运算 6 | 3=7
^: 异或运算 6^3=5
~: 反码 ~6=-7 */
//左移:左移就是乘以2的次幂运算。移几位就是几次幂。
//左移的用处:比如要在计算机中做3*4的运算,
//在计算机中是用二进制相乘的011*100,但是
//现在可以用位运算的方式(左移来运算),
//即把3左移2位就得到结果了,这样的运算速度很快,
//其弊端是只能操作2的倍数,在开发过程中如果要操作2
//的倍数或者2的次幂时,可用位运算来实现。 //右移:右移就是除以2的次幂运算。移几位就是几次幂。
/*
右移时,原最高位是什么,空位就补什么(保持原来的符号性)。
*/ //无符号右移:不用于做除法运算。
/*
无论原最高位是什么,空位都补0.
用处在于:获取二进制中某一段的值 比如:
一个二进制为:00000000 00111100 00000000 00110110
如果三位三位的获取其值(一次右移无符号三位),第一次
右移三位取得的是(110:结果为6),然后去掉这三位,则
下一个三位变成了最低的三位,再获取这个三位……最后得到的
结果是这个二进制对应的八进制数。(获取四位,就是二进制
对应的十六进制) 总结就是:在进行关于2的运算时,考虑左移和右移运算。
在进行二进制的位操作是,要用到无符号右移。
*/ //&运算:
/*
在二进制中在&运算过程中,只有全为1时,结果才为1,
否则为0. 用处是:在获取某一个二进制的某几位的时候比如:
一个二进制为00101011,要获取最后三位是可以用三个1和
最后三个二进制为相与
一句话:用来获取二进制中的有效位1
00101011
00000111
-----------
00000011------最后三位为二进制位
当要获取第二个三位时,可以先把此二进制无符号右移三位
在和00000111相与即可
*/ //|:运算
/*
6|3=
110
|001
----
111 --->7(十进制)
*/ //^:运算
/*
6^3=5
110
^011
----
101 --->5
^011
----
110 --->6
即6^3^3 = 6;
一个数异或另一个数,结果还是原数。(用于加密方面)
*/ //~:取反运算:
/*
~6=-7:计算如下:
6--->00000110 取反得:--->11111001
因为在计算机中是用补码形式存放的。所以要把11111001
看成一段补码,现在把这个补码转换为原码(先变为反码:
减1就行得--->11111000,再变为原码,最高位是符号位,不变
其他为按位取反得--->10000111再转化为十进制为-7)
比如6取反再加1得-6
*/ //位运算符的练习: /*
1,如何最有效率的计算2*8
通过左移来运算:2<<<3--->2*8 = 16;
//System.out.println(2<<3);--->结果是16
2, 对两个整数变量的值进行互换(不需要第三方变量)
int a = 3,b = 7; //通过第三方变量的方法如下:
int temp;
temp = a;
a = b;
b = temp; //(不经过第三方变量)通过和的形式。有个弊端,两个数据较大,可能会超出int范围。
//这个方法不太好
a = a+b; //a = 3+7;
b = a-b; //b = 3+7-7; b = 3;
a = a=b; //a = 3+7-3; a = 7; //(不经过第三方变量)通过位运算来解决。
a = a^b; //a = 3^7;
b = a^b; //b = 3^7^7; --->b = 3;
a = a^b; //a = 3^7^3; --->a = 7;
*/ //三元运算符:格式:(条件表达式)?表达式1:表达式2;
//int x = 2,y;
//y = x>1?100:200; //需求:有三个数,想知道最大的是哪个?
/*
int a = 2,b=3,c =4,max;
if(a>b)
max = a;
if(max<b)
max = b;
System.out.println("max="+max);
*/ class OperateDemo1
{
public static void main(String[] args)
{
int a=3,b=40,c=5;
int max;
if(a>b)
max = a;
else
max = b;
if(max<c)
max = c;
else
max = b;
System.out.println("max="+max); }
}

《JAVA---day03---运算符》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. [pytorch]pytorch loss function 总结

    原文: http://www.voidcn.com/article/p-rtzqgqkz-bpg.html 最近看了下 PyTorch 的损失函数文档,整理了下自己的理解,重新格式化了公式如下,以便以 ...

  2. JS进阶系列之this

    在javascript中,this的指向是在执行上下文的创建阶段确定的,其实只要知道不同执行方式下,this的指向分别是是什么,就能很好的掌握this这个让人摸不透的东西. 一.全局执行 全局执行又分 ...

  3. GBDT 简述

    GBDT 全称 Gradient Boosting Decision Tree,梯度提升决策树. 梯度增强决策树的思想来源于两个地方,首先是增强算法(Boosting),然后是梯度增强(Gradien ...

  4. hdu 1325 Is It A Tree? 并查集

    Is It A Tree? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  5. python 判断字符串是否以数字结尾

    import re def end_num(string): #以一个数字结尾字符串 text = re.compile(r".*[0-9]$") if text.match(st ...

  6. MINA2.0用户手册中文版

    MINA2.0用户手册中文版--第一章 MINA2.0入门 MINA2.0用户手册中文版--第二章 第一节 MINA应用程序架构 MINA2.0用户手册中文版--第二章 第二节 TCP服务端实例 MI ...

  7. Codeforces 285C - Building Permutation

    285C - Building Permutation 思路:贪心.因为每个数都不同且不超过n,而且长度也为n,所有排列只能为1 2 3 ......n.所以排好序后与对应元素的差值的绝对值加起来就是 ...

  8. C#对config配置文件的管理

    应用程序配置文件,对于asp.net是 web.config,对于WINFORM程序是App.Config(ExeName.exe.config). 配置文件,对于程序本身来说,就是基础和依据,其本质 ...

  9. codeforces 571a//Lengthening Sticks// Codeforces Round #317

    题意:三角形3条边,最多共添加ll长,问组成的合法三角形个数. 本来想用暴搜,觉得会超时就搜题解了.不过保证我解释得更清晰. 先计算ll长分配给3条边有几种分法?由于不分也是合法的,因此最后实际分出去 ...

  10. President's Path CodeForces - 416E (最短路,计数)

    大意: 给定无向图, 求任意两点间所有最短路经过的边数 刚开始想先用floyd跑出最短路, 然后在DAG上DP, 交了1发, 发现会算重复 贴一下题解的做法 #include <iostream ...