《JAVA---day03---运算符》
/*【位运算符】
运算符: 运算 范例 说明 <<: 左移 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---运算符》的更多相关文章
- 简单物联网:外网访问内网路由器下树莓派Flask服务器
最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...
- 利用ssh反向代理以及autossh实现从外网连接内网服务器
前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...
- 外网访问内网Docker容器
外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...
- 外网访问内网SpringBoot
外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...
- 外网访问内网Elasticsearch WEB
外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...
- 怎样从外网访问内网Rails
外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...
- 怎样从外网访问内网Memcached数据库
外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...
- 怎样从外网访问内网CouchDB数据库
外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...
- 怎样从外网访问内网DB2数据库
外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...
- 怎样从外网访问内网OpenLDAP数据库
外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...
随机推荐
- [pytorch]pytorch loss function 总结
原文: http://www.voidcn.com/article/p-rtzqgqkz-bpg.html 最近看了下 PyTorch 的损失函数文档,整理了下自己的理解,重新格式化了公式如下,以便以 ...
- JS进阶系列之this
在javascript中,this的指向是在执行上下文的创建阶段确定的,其实只要知道不同执行方式下,this的指向分别是是什么,就能很好的掌握this这个让人摸不透的东西. 一.全局执行 全局执行又分 ...
- GBDT 简述
GBDT 全称 Gradient Boosting Decision Tree,梯度提升决策树. 梯度增强决策树的思想来源于两个地方,首先是增强算法(Boosting),然后是梯度增强(Gradien ...
- 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 ...
- python 判断字符串是否以数字结尾
import re def end_num(string): #以一个数字结尾字符串 text = re.compile(r".*[0-9]$") if text.match(st ...
- MINA2.0用户手册中文版
MINA2.0用户手册中文版--第一章 MINA2.0入门 MINA2.0用户手册中文版--第二章 第一节 MINA应用程序架构 MINA2.0用户手册中文版--第二章 第二节 TCP服务端实例 MI ...
- Codeforces 285C - Building Permutation
285C - Building Permutation 思路:贪心.因为每个数都不同且不超过n,而且长度也为n,所有排列只能为1 2 3 ......n.所以排好序后与对应元素的差值的绝对值加起来就是 ...
- C#对config配置文件的管理
应用程序配置文件,对于asp.net是 web.config,对于WINFORM程序是App.Config(ExeName.exe.config). 配置文件,对于程序本身来说,就是基础和依据,其本质 ...
- codeforces 571a//Lengthening Sticks// Codeforces Round #317
题意:三角形3条边,最多共添加ll长,问组成的合法三角形个数. 本来想用暴搜,觉得会超时就搜题解了.不过保证我解释得更清晰. 先计算ll长分配给3条边有几种分法?由于不分也是合法的,因此最后实际分出去 ...
- President's Path CodeForces - 416E (最短路,计数)
大意: 给定无向图, 求任意两点间所有最短路经过的边数 刚开始想先用floyd跑出最短路, 然后在DAG上DP, 交了1发, 发现会算重复 贴一下题解的做法 #include <iostream ...