【韩顺平Java笔记】第4章:运算符

文章目录

  • 61. 上一章总结
  • 62. 算术运算符介绍
    • 62.1 运算符介绍
    • 62.2 算术运算符介绍
    • 62.3 算术运算符一览
  • 63. 算术运算符使用
  • 64. 算术运算符练习1
  • 65. 算术运算符练习2
  • 66. 67. 算术运算符练习3,4
  • 68. 关系运算符介绍
    • 68.1 关系运算符介绍
    • 68.2 关系运算符一览
  • 69. 关系运算符使用
  • 70. 逻辑运算符
    • 70.1 逻辑运算符一览
  • 71. 短路与逻辑与
    • 71.1 &&和&基本规则
    • 71.2 &&和&使用区别
  • 72. 短路或逻辑或
    • 72.1 ||和|基本规则
    • 72.2 || 和 | 使用区别
  • 73. 逻辑非逻辑异或
    • 73.1 逻辑非
    • 73.2 逻辑异或
  • 74. 逻辑运算符练习
  • 75. 赋值运算符介绍
    • 75.1 介绍
    • 75.2 赋值运算符的分类
  • 76. 赋值运算符细节
  • 77. 三元运算符介绍
  • 78. 三元运算符细节
  • 79. 三元运算符练习
  • 80. 运算符优先级
  • 81. 标识符规则
    • 81.1 标识符概念
    • 81.2 标识符的命名规则(必须遵守)
    • 82. 标识符练习
  • 83. 标识符规范
  • 84. 关键字保留字
    • 84.1 关键字
    • 84.2 保留字
  • 86. 键盘输入
    • 86.1 介绍
    • 86.2 步骤
    • 86.3 案例演示
  • 86. 四种进制介绍
    • 86.1 进制介绍
    • 86.2 进制的图示
  • 87. 二进制转十进制
  • 88. 八进制转十进制
  • 89. 十六进制转十进制
  • 90. 十进制转二进制
  • 91. 十进制转八进制
  • 92. 十进制转十六进制
  • 93. 二进制转八进制
  • 94. 二进制转十六进制
  • 95. 八进制转二进制
  • 96. 十六进制转二进制
  • 97. 位运算的思考题
  • 98. 原码,反码,补码
    • 98.1 二进制在运算中的说明
    • 98.2 源码、反码、补码(重点 难点)
  • 99. 位运算详解1
  • 100. 位运算详解2
  • 101. 本章作业

61. 上一章总结

看视频

62. 算术运算符介绍

62.1 运算符介绍

运算符是一种特殊的符号,用以表示数据的运算、赋值和比较等。

  1. 算术运算符;
  2. 赋值运算符;
  3. 关系运算符[比较运算符];
  4. 逻辑运算符;
  5. 位运算符;
  6. 三元运算符

62.2 算术运算符介绍

算术运算符是对数值类型的变量进行运算的,在Java车光绪中使用的非常多。

62.3 算术运算符一览

运算符运算范例结果
+正号+77
-负号b=11; -b-11
+9+918
-10-82
*7*856
/9/91
%取模(取余) a % b = a − ⌊ a b ⌋ ⋅ b a\%b=a-\left \lfloor \frac{a}{b} \right \rfloor\cdot b a%b=abab11%92
++(放前面)自增,先运算后取值a=2;b=++a;a=3;b=3
++(放后面)自增,先取值后运算a=2;b=a++;a=3;b=2
–(放前面)自减,先运算后取值a=2;b=–a;a=1;b=1
–(放后面)自减,先取值后运算a=2;b=a–;a=1;b=2
+字符串相加“hsp” + “edu”“hsp edu”

63. 算术运算符使用

演示代码:

public class ArithmeticOperator
{public static void main(String[] args){System.out.println(10 / 4);//运算符两边精度最高的都是int,所以结果也是int(2)System.out.println(10.0 / 4);//精度最高的是double类型,结果是2.5double d = 10/4;//精度最高的还是int,所以结果先算成int类型,即2,再转成double,即2.0System.out.println(d);//取模//%得本质,看一个公式a % b =a - a / b * b//-10 % 3 => -10 - (-10)/3*3=-10 - (-3)*3=-1//10 % -3 => 10 - 10/(-3)*(-3)=10 - 9 =1//-10 % 3 => -10 - (-10)/3 * 3=-10 + 9 =-1System.out.println(10 % 3);//10/3求余数,得1System.out.println(-10 % 3);//-1System.out.println(10 % -3);//1System.out.println(-10 % -3);//-1//++的使用int i = 10;i++;//独立使用++,放前面和放后面是一样的++i;System.out.println("i=" + i);/** 作为表达式使用* 前++ : ++i先自增后赋值* 后++ : i++先赋值后自增*/int j = 8;int k = ++j;//等价于两条语句j=j+1;k=j;System.out.println("k=" + k + "\nj=" + j);//9 9int j1 = 8;int k1 = j1++;//等价于两条语句k1=j1;j1=j1+1;System.out.println("k1=" + k1 + "\nj1=" + j1);//8  9}
}

运行结果:
2
2.5
2.0
1
-1
1
-1
i=12
k=9
j=9
k1=8
j1=9

64. 算术运算符练习1

  1. int i = 1;
    i = i++;
    System.out.println(i);
    问:结果是多少?为什么?
    【答】(1)使用临时变量:temp = i;
    (2)i = i+1;
    (3)i = temp;
    所以输出的结果是1

  2. int i = 1;
    i = ++i;
    System.out.println(i);
    【答】(1)i = i+1;
    (2)temp = i;
    (3)i = temp;
    所以输出的结果是2

65. 算术运算符练习2

  • 自增,自减课堂练习,看看输出什么
int i1 = 10;
int i2 = 20;
int i = i1++;
System.out.print("i="+i);
System.out.println("i2="+i2);
i= --i2;
System.out.print("i="+i);
System.out.println("i2="+i2);

【答】输出结果为:
i=10i2=20
i=19i2=19
int i = i1++;//先给i1赋值给temp变量temp为10,然后i1自增1变为11,然后i变为temp的值10
i= --i2;// i2先自减,i2变为19,然后temp变为i2当前值19,将temp的值赋值给i,i也变为19

66. 67. 算术运算符练习3,4

  1. 假如还有59天放假,问:合xx个星期零xx天。
  2. 定义一个变量保存华氏温度,华氏温度转换摄氏温度的公式为5/9*(华氏温度-100),请求出华氏温度234.5度对应的摄氏温度。
    【答】
public class ArithmeticOperatorExercise02
{public static void main(String[] args){//需求:假如还有59天放假,问:合xx个星期零xx天。//思路分析://(1)使用int变量days保存天数//(2)一个星期是7天 星期数weeks: days / 7 零 xx天 leftDays % 7//(3)输出int days = 59;int weeks = days / 7;int leftDays = days % 7;System.out.println("合" + weeks + "个星期零" + leftDays + "天");//需求:定义一个变量保存华氏温度,华氏温度转换摄氏温度的公式为5/9*(华氏温度-100),请求出华氏温度234.5度对应的摄氏温度。//思路分析//(1)先定义一个double huaShi 变量保存 华氏温度//(2)根据给出的公式,进行计算即可5/9*(华氏温度-100),考虑数学公式和java语言的特性//(3)将得到的结果保存到double sheShidouble huaShi = 234.5;double sheShi = 5 / 9.0 * (huaShi - 100);//注意变量中得有double类型,写个9.0,要不然就变成整数的除法会出现精度丢失System.out.println("华氏温度" + huaShi + "对应的摄氏温度=" + sheShi);}
}

运行结果:
合8个星期零3天
华氏温度234.5对应的摄氏温度=74.72222222222223

68. 关系运算符介绍

68.1 关系运算符介绍

  1. 关系运算符的结果都是boolean型,也就是要么是true,要么是false
  2. 关系表达式经常用在if结构的条件中或循环结构的条件中

68.2 关系运算符一览

运算符运算范例结果
==相当于8==7false
!=不等于8!7true
<小于8<7false
>大于8>7true
<=小于等于8<=7false
>=带等于8>=7true
instanceof检查是否是类的对象“hsp” instanceof Stringtrue

69. 关系运算符使用

public class RelationOperator {public static void main(String[] args) {int a = 9;// 提示:开发中,不可以使用 a, b a1,bc n1,n2...int b = 8;System.out.println(a > b);//TSystem.out.println(a >= b);//TSystem.out.println(a <= b);//FSystem.out.println(a < b);//FSystem.out.println(a == b);//FSystem.out.println(a != b);//Tboolean flag = a > b;//TSystem.out.println("flag=" + flag);}
}

运算结果:
true
true
false
false
false
true
flag=true

  • 细节说明
    1)关系运算符的结果都是boolean型,也就是要么是true,要么是false。
    2)关系运算符组成的表达式,我们称为关系表达式。a>b
    3)比较运算符"==“不能误写成”="

70. 逻辑运算符

用于连接多个条件(多个关系表达式),最终的结果也是一个boolean值。

70.1 逻辑运算符一览

1)短路与 &&,短路或||,取反!
2)逻辑与&,逻辑或|,^逻辑异或
其真值表如下:

  • 说明逻辑运算规则:
  1. a&b:& 叫逻辑与:规则:当a 和 b 同时为true,则结果为true,否则为false
  2. a&&b:&& 叫短路与:规则:当a 和b 同时为true ,则结果为true,否则为false
  3. alb : | 叫逻辑或,规则:当a 和 b,有一个为true,则结果为true,否则为false
  4. alb : | 叫短路或,规则:当a 和 b,有一个为true ,则结果为true,否则为false
  5. !a:叫取反,或者非运算。当a 为true,则结果为false,当a为false是,结果为true
  6. a^b: 叫逻辑异或,当 a和 b 不同时,则结果为true,否则为false

71. 短路与逻辑与

71.1 &&和&基本规则

名称语法特点
短路与&&条件1&&条件2两个条件都为true,结果为true,其他情况为false
逻辑与&条件1&条件2两个条件都为true,结果为true ,其他情况为false

71.2 &&和&使用区别

短路与和逻辑与其运算结果一样,但是它们是有区别的。

  1. &&短路与:如果第一个条件为 false,则第二个条件不会判断,最终结果为 false,效率高
  2. & 逻辑与:不管第一个条件是否为 false,第二个条件都要判断,效率低
  3. 开发中, 我们使用的基本是使用短路与&&, 效率高
    演示代码:
public class LogicOperator01
{public static void main(String[] args){//&& 和 &案例演示int age = 50;if(age > 20 && age < 90){System.out.println("ok100");}if(age > 20 & age < 90){System.out.println("ok200");}//区别int a = 4;int b = 9;//对于&&短路与而言,如果第一个条件为 false ,后面的条件不再判断//对于&逻辑与而言,如果第一个条件为 false ,后面的条件仍然会判断//a<1为假,假与真结果为假,不输出if(a < 1 && ++b < 50){System.out.println("ok300");}//输出a=4,b=9,++b并没有执行System.out.println("a=" + a);System.out.println("b=" + b);if(a < 1 & ++b < 50){System.out.println("ok300");}//输出a=4,b=10,++b执行了System.out.println("a=" + a);System.out.println("b=" + b);}
}

运行结果:
ok100
ok200
a=4
b=9
a=4
b=10

72. 短路或逻辑或

72.1 ||和|基本规则

名称语法特点
短路或||条件1||条件2两个条件中只要有一个成立,结果为true,否则为 false
逻辑或|条件1|条件2两个条件中只要有一个成立,结果为true,否则为 false

72.2 || 和 | 使用区别

  1. ||短路或:如果第一个条件为 true,则第二个条件不会判断,最终结果为 true,效率高
  2. | 逻辑或:不管第一个条件是否为 true,第二个条件都要判断,效率低
  3. 开发中,我们基本使用 ||

演示代码:

public class LogicOperator02
{public static void main(String[] args){//||短路或 和 |逻辑或 案例演示//|| 规则: 两个条件中只要有一个成立,结果为 true,否则为 false//| 规则: 两个条件中只要有一个成立,结果为 true,否则为 falseint age = 50;//有一个为真则为真if(age > 20 || age < 30) {System.out.println("ok100");}if(age > 20 | age < 30) {System.out.println("ok200");}//看看区别//(1)||短路或:如果第一个条件为 true,//则第二个条件不会判断,最终结果为 true,效率高//(2)| 逻辑或:不管第一个条件是否为 true,第二个条件都要判断,效率低int a = 4;int b = 9;if(a>1 || ++b > 4){System.out.println("ok300");}System.out.println("a=" + a + " b=" + b); //4 9if(a>1 | ++b > 4){System.out.println("ok300");}System.out.println("a=" + a + " b=" + b); //4 10}
}

运行结果:
ok100
ok200
ok300
a=4 b=9
ok300
a=4 b=10

73. 逻辑非逻辑异或

73.1 逻辑非

取反的基本规则:

名称语法特点
!非(取反)!条件如果条件本身为true,结果为false,否则为true

73.2 逻辑异或

a^b: 叫逻辑异或,当 a 和 b 不同时,则结果为 true, 否则为 false

演示代码:

public class InverseOperator
{public static void main(String[] args){//! 操作是取反 T->F , F -> TSystem.out.println(60 > 20); //TSystem.out.println(!(60 > 20)); //F//a^b: 叫逻辑异或,当 a 和 b 不同时,则结果为 true, 否则为 falseboolean b = (10 > 1) ^ ( 3 > 5);System.out.println("b=" + b);//T}
}

运行结果:
true
false
b=true

74. 逻辑运算符练习

练习题 1 请写出每题的输出结果

详细可以看视频,规则就是上面那些运算符的规则

练习题 2 请写输出结果

if((z++==46)&&(y=true)) z++;//z和46先比较,再自增,所以第一个条件为True,第二个条件y=true后的结果为true,所以逻辑与的结果为true,z++执行;
下面同理

75. 赋值运算符介绍

75.1 介绍

赋值运算符就是将某个运算后的值,赋给指定的变量。

75.2 赋值运算符的分类

基本赋值运算符 =
复合赋值运算符
+= ,-= ,*= , /= ,%= 等 , 重点讲解一个 += ,其它的使用是一个道理
a += b; [等价 a = a + b; ]
a -= b; [等价 a = a - b; ]

76. 赋值运算符细节

赋值运算符特点

  1. 运算顺序从右往左 int num = a + b + c;
  2. 赋值运算符的左边 只能是变量,右边 可以是变量、表达式、常量值
    int num = 20; int num2= 78 * 34 - 10; int num3 = a;
  3. 复合赋值运算符等价于下面的效果
    比如:a+=3;等价于 a=a+3; 其他类推
  4. 复合赋值运算符会进行类型转换。
    byte b = 2; b+=3; b++;
public class AssignOperator
{public static void main(String[] args) {int n1 = 10;n1 += 4;// n1 = n1 + 4System.out.println(n1);n1 /= 3;//n1 = n1 / 3System.out.println(n1);//4//复合赋值运算符会进行类型转换byte b = 3;//符合-128~127b += 2; // 等价于b = b + 2;,这个b+2结果是int值,按理说是不正确的,但是它是赋值运算符,能够自动转换类型为byte,所以正确b++; //同理也可以}
}

运行结果:
14
4

77. 三元运算符介绍

条件表达式 ? 表达式 1: 表达式 2;
运算规则:

  1. 如果条件表达式为 true,运算后的结果是表达式 1;
  2. 如果条件表达式为 false,运算后的结果是表达式 2;

演示代码:

public class TernaryOperator
{public static void main(String[] args) {int a = 10;int b = 99;// 解读// 1. a > b 为 false// 2. 返回 b--, 先返回 b 的值,然后在 b-1,如果是--b,那先b自减,再返回自减后的b的值// 3. 返回的结果是 99int result = a > b ? a++ : b--;System.out.println("result=" + result);System.out.println("a=" + a);System.out.println("b=" + b);}
}

运行结果:
result=99
a=10
b=98

78. 三元运算符细节

  1. 表达式 1 和表达式 2 要为可以赋给接收变量的类型(或可以自动转换)
  2. 三元运算符可以转成 if–else 语句
    int res = a > b ? a++ : --b;
    等价为
    if ( a > b) res = a++;
    else res = --b;
public class TernaryOperatorDetail
{public static void main(String[] args) {//表达式 1 和表达式 2 要为可以赋给接收变量的类型(或可以自动转换)int a = 3;int b = 8;int c = a > b ? a : b;//返回a和b的最大值//int c1 = a > b ? 1.1 : 3.4;//返回a和b的最大值,错误,不能给double赋值给int,自动转换只能从低精度到高精度,加上强制类型转换就okdouble d = a> b ? a : b + 3;//低精度到高精度可以}
}

79. 三元运算符练习

案例:实现三个数的最大值

public class TernaryOperatorExercise
{public static void main(String[] args) {int n1 = 55;int n2 = 33;int n3 = 123;//思路//1. 先得到n1和n2中最大数,保存到max1//2. 然后再求出max1 和 n3中的最大数,保存到max2int max1 = n1 > n2 ? n1 : n2;int max2 = max1 > n3 ? max1 : n3;System.out.println("最大数=" + max2);//使用一条语句实现//上面更清晰,可读性强//后面用更好的方法来解决int max = (n1 > n2 ? n1 : n2) > n3 ? (n1 > n2 ? n1 : n2) : n3;System.out.println("最大数=" + max);}
}

运行结果:
最大数=123
最大数=123

80. 运算符优先级

  1. 运算符有不同的优先级,所谓优先级就是表达式运算中的运算顺序。如右表,上一行运算符总优先于下一行。
  2. 只有单目运算符、赋值运算符是从右向左运算的。
  3. 一览表, 不要背,使用多了,就熟悉了

    【注】L代表left左,R代表Right右

81. 标识符规则

  • 标识符的命名规则和规范

81.1 标识符概念

  1. Java对各种变量、方法和类等命名时使用的字符序列称为标识符;
  2. 凡是可以自己起名字的地方都叫标识符 int num1 = 90;

81.2 标识符的命名规则(必须遵守)

  1. 由26个英文字母大小写,数字0-9,_或$组成;比如int a b;不可以(因为中间有空格)
  2. 数字不可以开头。 错误例子如int 3ab = 1;
  3. 不可以使用关键字(比如class)和保留字,但可以包含关键字和保留字(比如abcclass);
  4. Java中严格区分大小写,长度无限制。比如:int totalNum = 10; int totalnum = 90;是两个不同的变量
  5. 标识符不能包含空格。int a b = 90;

82. 标识符练习

hsp //ok
hsp12 //ok
1hsp //错误, 数字不能开头
h-s // 错误 , 不能有 - x h // 错误, 有空格
h$4 // ok
class //错误,class 关键字
int // 错误 ,int 是关键字
double //错误 ,double 是关键字
public //错误 ,public 是关键字
static //错误 ,static 是关键字
goto //错误, goto 是保留字
stu_name //ok

83. 标识符规范

  1. 包名:多单词组成时所有字母都小写:aaa.bbb.ccc //比如 com.hsp.crm
  2. 类名、接口名:多单词组成时,所有单词的首字母大写:XxxYyyZzz [大驼峰]
    比如: TankShotGame
  3. 变量名、方法名:多单词组成时,第一个单词首字母小写,第二个单词开始每个单词首字母大写:xxxYyyZzz [小
    驼峰, 简称 驼峰法]
    比如: tankShotGame
  4. 常量名:所有字母都大写。多单词时每个单词用下划线连接:XXX_YYY_ZZZ
    比如 :定义一个所得税率 TAX_RATE
  5. 后面我们学习到 类,包,接口,等时,我们的命名规范要这样遵守,更加详细的看文档.

84. 关键字保留字

84.1 关键字

关键字的定义和特点 (不用背)
定义:被 Java 语言赋予了特殊含义,用做专门用途的字符串(单词)
特点:关键字中所有字母都为小写

84.2 保留字

Java 保留字:现有 Java 版本尚未使用,但以后版本可能会作为关键字使用。自己命名标识符时要避免使用这些保留字 byValue、cast、future、 generic、 inner、 operator、 outer、 rest、 var 、 goto 、const

86. 键盘输入

86.1 介绍

在编程中,需要接收用户输入的数据,就可以使用键盘输入语句来获取。需要一个 扫描器(对象), 就是Scanner.

86.2 步骤

  1. 导入该类的所在包, java.util.*
  2. 创建该类对象(声明变量)
  3. 调用里面的功能

86.3 案例演示

要求:可以从控制台接收用户信息,【姓名,年龄,薪水】

import java.util.Scanner;//表示把java.util包下的Scanner类导入
public class Input
{public static void main(String[] args) {//演示接收用户的输入//步骤//Scanner类表示简单文本扫描器,在java.util包//1. 引入/导入 Scanner类所在的包//2. 创建Scanner对象,new创建一个对象//myScanner就是Scanner类的对象Scanner myScanner = new Scanner(System.in);//3. 接收用的输入,使用相关的方法System.out.println("请输入名字");//当程序执行到next方法时,会等待用户输入String name = myScanner.next(); //接收用户输入字符串,nextInt输入Int,以此类推,可看开发文档System.out.println("请输入年龄"); //接收用户输入intint age = myScanner.nextInt();System.out.println("请输入薪水");double sal = myScanner.nextDouble(); //接收用户输入doubleSystem.out.println("人的信息如下:");System.out.println("姓名:" + name + " 年龄=" + age + " 薪水" + sal);}
}

输入与输出结果:
请输入名字
jack
请输入年龄
18
请输入薪水
10000
人的信息如下:
姓名:jack 年龄=18 薪水10000.0

86. 四种进制介绍

86.1 进制介绍

对于整数,有四种表示方式:
二进制:0,1 ,满 2 进 1.以 0b 或 0B 开头。
十进制:0-9 ,满 10 进 1。
八进制:0-7 ,满 8 进 1. 以数字 0 开头表示。
十六进制:0-9 及 A(10)-F(15),满 16 进 1. 以 0x 或 0X 开头表示。此处的 A-F 不区分大小写。

//演示四种进制
public class BinaryTest
{public static void main(String[] args) {//n1 二进制int n1 = 0b1010;//2^1+2^3=2+8=10//n2 10 进制int n2 = 1010;//n3 8 进制int n3 = 01010;//n4 16 进制int n4 = 0X10101;System.out.println("n1=" + n1);System.out.println("n2=" + n2);System.out.println("n3=" + n3);System.out.println("n4=" + n4);System.out.println(0x23A);}
}

运行结果:
n1=10
n2=1010
n3=520
n4=65793
570

86.2 进制的图示

十进制十六进制八进制二进制
0000
1111
22210
33311
444100
555101
666110
777111
88101000
99111001
10A121010
11B131011
12C141100
13D151101
14E161110
15F171111
16102010000
17112110001

87. 二进制转十进制

【注】韩顺平老师提到的这些进制转换,均未涉及到符号位(负数)的问题,关于符号位的问题可以看计算机组成原理的书

88. 八进制转十进制

89. 十六进制转十进制

规则:从最低位(右边)开始,将每个位上的数提取出来,乘以 16 的(位数-1)次方,然后求和。
案例:请将 0x23A 转成十进制的数
0x23A = 10 * 16^0 + 3 * 16 ^ 1 + 2 * 16^2 = 10 + 48 + 512 = 570
课堂练习:请将
0b110001100 转成 十进制
【答】 0 b 110001100 = 2 2 + 2 3 + 2 7 + 2 8 = 396 0\text{b}110001100=2^2+2^3+2^7+2^8=396 0b110001100=22+23+27+28=396
02456 转成十进制
【答】 02456 = 6 × 8 0 + 5 × 8 1 + 4 × 8 2 + 2 × 8 3 = 1326 02456=6\times 8^0+5\times 8^1 +4\times 8^2+2\times 8^3=1326 02456=6×80+5×81+4×82+2×83=1326
0xA45 转成十进制
【答】 0 xA 45 = 5 × 1 6 0 + 4 × 1 6 1 + 10 × 1 6 2 = 2629 0\text{xA}45=5\times16^0+4\times16^1+10\times16^2=2629 0xA45=5×160+4×161+10×162=2629

90. 十进制转二进制

规则:将该数不断除以 2,直到商为 0 为止,然后将每步得到的余数倒过来,就是对应的二进制。
案例:请将 34 转成二进制 = 0B00100010

【注】0B00100010前面多两个0是因为一个字节有8位,要补一下。

91. 十进制转八进制

规则:将该数不断除以 8,直到商为 0 为止,然后将每步得到的余数倒过来,就是对应的八进制。
案例:请将 131 转成八进制 => 0203

92. 十进制转十六进制

规则:将该数不断除以 16,直到商为 0 为止,然后将每步得到的余数倒过来,就是对应的十六进制。
案例:请将 237 转成十六进制 => 0xED

课堂练习:(一定练习,使用计算器/用程序去验证)
123 转成 二进制 => ?
【答】0B01111011

678 转成八进制 => ?
【答】01246

8912 转成十六进制 => ?
【答】0X22D0

93. 二进制转八进制

规则:从低位开始,将二进制数每三位一组,转成对应的八进制数即可。
案例:请将 0b11010101 转成八进制
0b11(3)010(2)101(5) => 0325

94. 二进制转十六进制

规则:从低位开始,将二进制数每四位一组,转成对应的十六进制数即可。
案例:请将 ob11010101 转成十六进制
ob1101(D)0101(5) = 0xD5
课堂练习:请将
0b11100101 转成 八进制
【答】0b1110(14,E)0101(5) = 0xE5
0b1110010110 转成 十六进制
【答】0b11(3)1001(9)0110(6)=0x396

95. 八进制转二进制

规则:将八进制数每 1 位,转成对应的一个 3 位的二进制数即可。
案例:请将 0237 转成二进制
02(010)3(011)7(111) = 0b10011111
【注】保持一个字节8位二进制,最左侧的0可以省略

96. 十六进制转二进制

规则:将十六进制数每 1 位,转成对应的 4 位的一个二进制数即可。
案例:请将 0x23B 转成二进制
0x2(0010)3(0011)B(1011) = 0b001000111011
课堂练习:请将
01230 转成 二进制
【答】1(001)2(010)3(011)0(000)=0B1010011000
0xAB29 转成二进制
【答】0xA(1010)B(1011)2(0010)9(1001)=0B1010 1011 0010 1001

97. 位运算的思考题

抛砖引玉引出两个题目,以便后面介绍位运算

  1. 请看下面的代码段,回答 a,b,c,d,e 结果是多少?
public static void maiin(String []args)
{int a=1>>2; // 1 向右位移 2 位int b=-1>>2;//算术右移int c=1<<2;//算术左移int d=-1<<2;//int e=3>>>2;//无符号右移//a,b,c,d,e 结果是多少System.out.println("a="+a);System.out.println("b="+b);System.out.println("c="+c);System.out.println("d="+d);System.out.println("e="+e);
}
  1. 请回答在 java 中,下面的表达式运算的结果是: (位操作)
    ~2=? // 按位取反
    2&3=?// 2 按位与 3
    2|3=? ~-5=?
    13&7=?
    5|4=?
    -3^3=?//^ 按位异或

98. 原码,反码,补码

98.1 二进制在运算中的说明

  1. 二进制是逢2进位的进位制,0、1是基本算符。
  2. 现代的电子计算机技术全部采用的是二进制,因为它只使用0、1两个数字符号,非常简单方便,易于用电子方式实现。计算机内部处理的信息,都是采用二进制数来表示的。二进制(Binary)数用0和1两个数字及其组合来表示任何数。进位规则是"逢2进1",数字1在不同的位上代表不同的值,按从右至左的次序,这个值以二倍递增。

98.2 源码、反码、补码(重点 难点)

网上对原码,反码,补码的解释过于复杂,我这里精简几句话:
对于有符号的而言:

  1. 二进制的最高位是符号位:0表示正数,1表示负数(口诀:0->0 1->-)
  2. 正数的原码,反码,补码都一样(三码合一)
  3. 负数的反码=它的原码符号位不变,其它位取反(0->1,1->0)
  4. 负数的补码=它的反码+1,负数的反码= 负数的补码-1
  5. 0的反码,补码都是0
  6. java没有无符号数,换言之,java中的数都是有符号的
  7. 在计算机运算的时候,都是以补码的方式来运算的.
  8. 当我们看运算结果的时候,要看他的原码

99. 位运算详解1

java 中有 7 个位运算(&、|、^ 、~、>>、<<和 >>>)

public class BitOperator
{public static void main(String[] args) {//先得到2的补码,这两个数都是int型,占四个字节,(正数补码就是原码)//所以2的补码为00000000 00000000 00000000 00000010B//3的补码为00000000 00000000 00000000 00000011B//按位与的结果为00000000 00000000 00000000 00000010B(补码)//结果的补码恰好是正数,补码就是原码//即十进制的2System.out.println(2 & 3);//-2原码为10000000 00000000 00000000 00000010//-2的反码为11111111 11111111 11111111 11111101(反码符号位不变)//-2的补码为反码+1即11111111 11111111 11111111 11111110//然后对-2的补码按位取反00000000 00000000 00000000 00000001(按位取反符号位变)//即运算后的补码为00000000 00000000 00000000 00000001//正数,则补码就是原码,即十进制的1System.out.println(~-2);//2是正数,补码就是原码,即00000000 00000000 00000000 00000010//对2的补码取反就是11111111 11111111 11111111 11111101//得到结果的补码是11111111 11111111 11111111 11111101//对结果的补码-1就是反码即11111111 11111111 11111111 11111100//结果的反码的反码就是原码即10000000 00000000 00000000 00000011//(取反码和取反不同,取反码符号位不变,取反符号位也变)//也就是十进制的-3System.out.println(~2);//2的补码为00000000 00000000 00000000 00000010B//3的补码为00000000 00000000 00000000 00000011B//按位或结果的补码为00000000 00000000 00000000 00000011B//正数,补码和原码一样,即十进制的3System.out.println(2|3);//2的补码为00000000 00000000 00000000 00000010B//3的补码为00000000 00000000 00000000 00000011B//按位异或结果的补码为00000000 00000000 00000000 00000001B//正数,补码和原码一样,即十进制的1System.out.println(2^3);}
}

运行结果:
2
1
-3
3
1

100. 位运算详解2

还有 3 个位运算符 >>、<< 和 >>> , 运算规则:

  1. 算术右移 >>:低位溢出,符号位不变,并用符号位补溢出的高位
  2. 算术左移 <<: 符号位不变,低位补 0
  3. >>>逻辑右移也叫无符号右移,运算规则是: 低位溢出,高位补 0
  4. 特别说明:没有 <<< 符号
public class BitOperator02
{public static void main(String[] args) {//1 => 0000000 00000000 00000000 000000(01)B,用符号位补括号的内容//即变成0000000 00000000 00000000 00000000B//它的本质是1/2/2 == 0System.out.println(1>>2);//1 => 0000000 00000000 00000000 000000(01)B,将括号和其括号前面除符号位外左移两位//空出来的右侧的两位补0,即//0000000 00000000 00000000 00000100B//它的本质是1*2*2=4System.out.println(1<<2);System.out.println(4<<3);//相当于4*2*2*2=4*2的3次方=32System.out.println(15>>2);//相当于15/2/2=15/(2的平方)=3(int类型,除法损失精度)//前面的题int a=1>>2; // 1 向右位移 2 位(除两次2,结果为0)//-1的原码是10000000 00000000 00000000 00000001B//-1的反码是11111111 11111111 11111111 11111110B//-1的补码是11111111 11111111 11111111 111111(11)B//算数右移,符号位补溢出的高位,即(11)及其左侧向右移动(除符号位,空出来的两个位用符号位补齐)//结果的补码为11111111 11111111 11111111 11111111B//和-1的补码一致,所以b=-1>>2还是-1int b=-1>>2;//算术右移//1*2*2=4int c=1<<2;//算术左移//-1的原码是10000000 00000000 00000000 00000001B//-1的反码是11111111 11111111 11111111 11111110B//-1的补码是11111111 11111111 11111111 111111(11)B//左移两位,符号位不变,低位补0,(11)及其左侧非符号位向左移动//结果的补码是11111111 11111111 11111111 11111100B//结果的反码是补码-1即11111111 11111111 11111111 11111011B(借位减法)//结果的原码是反码的反码即10000000 00000000 00000000 00000100B//即十进制的-4//也即-1*2*2=-4int d=-1<<2;////3的二进制是00000000 00000000 00000000 00000011B//正数,补码和原码一致//无符号右移,低位溢出,高位补0,右移动2位//得到结果的补码是00000000 00000000 00000000 00000000B//正数,补码和原码一致,即十进制的0int e=3>>>2;//无符号右移//a,b,c,d,e 结果是多少System.out.println("a="+a);System.out.println("b="+b);System.out.println("c="+c);System.out.println("d="+d);System.out.println("e="+e);}
}

运行结果为:
0
4
32
3
a=0
b=-1
c=4
d=-4
e=0
【注】带符号右移不仅仅是简单的除以2:它还包含了对符号位的处理,以保持数的符号不变。如果你期望通过右移实现严格的数学除法,这种行为可能会让结果与预期不符,特别是对于负数。

101. 本章作业

  1. 计算下列表达式的结果
    10/3 = ?;
    10/5 = ?;
    10%2 = ?;
    -10.5%3 = ?;
    【答】10/3 == 3
    10/5 == 2
    10%2 == 0
    -10.5 % 3(按公式a % b = a - (int)a / b * b即 a % b = a − ⌊ a b ⌋ ⋅ b a\%b=a-\left \lfloor \frac{a}{b} \right \rfloor\cdot b a%b=abab) ==-10.5-((-10.5)/3) *3==-10.5+3*3(标了小数点就是double类型)==-1.5
    【注】有小数运算,得到结果是近似值。
  2. 试说出下面代码的结果
    int i = 66;
    System.out.println(++i+i);
    【答】
    ++i是先让i自增然后再做运算(i++是先做运算,运算后自增),即i自增变成67后,然后再进行i+i,即67+67,输出结果是134

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1551960.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

仿真设计|基于51单片机的温湿度及PM2.5监测系统仿真

目录 具体实现功能 设计介绍 51单片机简介 资料内容 仿真实现&#xff08;protues8.7&#xff09; 程序&#xff08;Keil5&#xff09; 全部内容 资料获取 具体实现功能 &#xff08;1&#xff09;LCD1602液晶第一行显示当前的PM2.5值&#xff0c;第二行显示当前的温度…

观测云对接 SkyWalking 最佳实践

简介 SkyWalking 是一个开源的 APM&#xff08;应用性能监控&#xff09;和可观测性分析平台&#xff0c;专为微服务、云原生架构和基于容器的架构设计。它提供了分布式追踪、服务网格遥测分析、度量聚合和可视化一体化的解决方案。如果您的应用中正在使用SkyWalking &#xf…

25中国烟草校园招聘面试问题总结 烟草面试全流程及面试攻略

开头附上工作招聘面试必备问题噢~~包括综合面试题、无领导小组面试题资源文件免费&#xff01;全文干货。 工作招聘无领导小组面试全攻略最常见面试题&#xff08;第一部分&#xff09;共有17章可用于国企私企合资企业工作招聘面试面试必备心得面试总结资源-CSDN文库https://d…

家庭教育研究编辑部家庭教育研究杂志社2024年第14期目录

特别关注 幼儿园主题课程生活化资源的开发与利用 包丽梅1-3 探讨提高小学信息科技教学效率的策略 王小峰4-6 幼儿园实施体育游戏教学的策略研究 邵惇妹7-9 中华优秀传统文化融入小学德育课堂策略探究 梁叶华10-12 幼儿园新生入园分离焦虑研究 郭舒苗13-15 协同育人 …

实验5 预备实验2-配置单个的路由器

配置单个的路由器 一、实验目的 此次试验目的是了解思科网络设备的配置基本特点及IOS命令基本操作方法。这些是配置思科设备的重要前提。 二、实验内容及结果 1、实验环境搭建 添加一个模块化的路由器&#xff0c;单击Packet Tracer 5.3的工作区中刚添加的路由器&#xff0c;…

基于无人机图像的洪水灾害受损评估分割数据集,共4494张高清无人机图像,10个类别,共22GB数据量,主要关注道路,建筑的受损情况。洪水应急救援

洪水应急救援&#xff0c;基于无人机图像的洪水灾害受损评估分割数据集&#xff0c;共4494张高清无人机图像&#xff0c;10个类别&#xff0c;共22GB数据量&#xff0c;主要关注道路&#xff0c;建筑的受损情况。 洪水应急救援&#xff0c;基于无人机图像的洪水灾害受损评估分…

【含文档】基于Springboot+Vue的工资管理系统(含源码+数据库+lw)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统定…

真正的Open AI ——LLaMA颠覆开源大模型

1. LLaMA 简介 LLaMA&#xff08;Large Language Model Meta AI&#xff09;是由Meta&#xff08;原Facebook&#xff09;推出的一个大型语言模型系列&#xff0c;旨在通过更小的模型规模和更少的计算资源&#xff0c;实现与其他主流语言模型&#xff08;如GPT&#xff09;相媲…

机器人的性能指标

1. 负荷能力 负荷能力负荷能力是指机器人在满足其他性能要求的情况下,能够承载的负荷重量。例如,一台机器人的最大负荷能力可能远大于它的额定负荷能力,但是达到最大负荷时,机器人的工作精度可能会降低,可能无法准确地沿着预定的轨迹运动,或者产生额外的偏差。机器人的负荷量与…

\?拉普拉斯到底在讲什么\?控制理论\?倒立摆/

在大学课程中&#xff0c;无疑控制理论难倒了一大堆同学&#xff0c;那么接下来&#xff0c;从实践中来分析这个控制理论。 首先上场的就是拉普拉斯变化。上篇文章说了一下傅里叶函数的作用和使用&#xff0c;简单回顾一下&#xff1a; 傅里叶变换就是将一个周期或非周期的信号…

埃及 Explained

古埃及&#xff0c;位于尼罗河畔的神秘文明&#xff0c;曾在北非的荒漠中繁荣昌盛。这个充满谜团的王国凭借其宏伟的成就和神秘的文化&#xff0c;数百年来吸引了无数人的好奇心。 埃及人创造了复杂的象形文字&#xff0c;建造了像吉萨大金字塔这样宏伟的建筑&#xff0c;并通…

【D3.js in Action 3 精译_026】3.4 小节 DIY 实战:基于 Mocha 在浏览器客户端测试 D3 线性比例尺

当前内容所在位置&#xff08;可进入专栏查看其他译好的章节内容&#xff09; 第一部分 D3.js 基础知识 第一章 D3.js 简介&#xff08;已完结&#xff09; 1.1 何为 D3.js&#xff1f;1.2 D3 生态系统——入门须知1.3 数据可视化最佳实践&#xff08;上&#xff09;1.3 数据可…

Python 机器学习:预测国庆黄金周的消费趋势

摘要&#xff1a;国庆黄金周作为中国一年中重要的消费高峰期&#xff0c;吸引了众多商家、政府和分析师关注。利用 Python 和机器学习技术&#xff0c;可以通过历史数据和多维因素构建模型&#xff0c;预测这一期间的消费趋势。本文介绍了数据获取、特征工程、模型选择和优化的…

Master PDF Editor 下载及详细安装教程

具体安装方式如下&#xff1a; 下载&#xff1a; MasterPDFEditor 先解压&#xff0c;将解压后的如下文件发送到桌面快捷方式 启动发送后桌面图标 选择要打开的pdf文档&#xff0c;可以看到打开速度是超级快&#xff0c;正常使用&#xff0c;操作简单方便

【网络安全】内部应用中的多重漏洞利用

未经许可,不得转载。 文章目录 初步发现:帐户枚举利用帐户枚举发现 IDOR 导致帐户接管拦截请求洪水攻击:注册拒绝服务目标网站:https://redacted.com 初步发现:帐户枚举 在最近的一次渗透测试中,我对一个仅供员工使用的内部应用程序进行了评估,重点关注身份验证和帐户…

Golang | Leetcode Golang题解之第448题找到所有数组中消失的数字

题目&#xff1a; 题解&#xff1a; func findDisappearedNumbers(nums []int) (ans []int) {n : len(nums)for _, v : range nums {v (v - 1) % nnums[v] n}for i, v : range nums {if v < n {ans append(ans, i1)}}return }

【原创】基于websocket的实时文本转语音功能

功能实现&#xff0c;将长文本分段实时转成音频流&#xff0c;达到边转换边播放的效果&#xff0c;减少等待效果&#xff0c;像豆包通义千问chatgpt差不多也是这样实现的&#xff0c; 下面的效果展示 20240930_084035_哔哩哔哩_bilibili【原创】基于websocket的实时文本转语音…

共和国勋章获得者:李振声

李振声&#xff0c;1931年2月出生于山东淄博&#xff0c;是中共党员、著名遗传学家和小麦遗传育种专家&#xff0c;兼任中国科学院院士和第三世界科学院院士。 他被誉为“中国小麦远缘杂交之父”和“当代后稷”&#xff0c;是中国小麦远缘杂交育种的奠基人。 教育背景与早年经…

【基于布尔的盲注】

一、sql基础 Substr 我们看一下用法1里面的str就是我们需要截取的字符&#xff0c;pos是需要截取的位置&#xff0c;len是我们需要截取的长度&#xff0c;例如右边的substr(123456,1,1)意思就是截取’123456’从第一位开始截取&#xff0c;截取两位&#xff0c;到2为止&#…

如何在C语言中实现Doris异步执行Insert语句

如何在C语言中实现Doris异步执行Insert语句 Doris(原名Apache Doris)是一个现代化的MPP(Massively Parallel Processing)分析型数据库,适用于超大规模数据的实时查询和分析。为了在C语言中实现向Doris数据库异步插入数据,我们需要解决以下几个关键问题: 设置Doris客户端…