JAVA基础知识-进制的介绍与书写格式

chatgpt/2023/9/27 6:33:57

1. 进制的介绍与书写格式

1.1 进制的介绍与书写格式

代码 :

public class Demo1 {/*十进制:Java中,数值默认都是10进制,不需要加任何修饰。二进制:数值前面以0b开头,b大小写都可以。八进制:数值前面以0开头。十六进制:数值前面以0x开头,x大小写都可以。注意: 书写的时候, 虽然加入了进制的标识, 但打印在控制台展示的都是十进制数据.*/public static void main(String[] args) {System.out.println(10);System.out.println("二进制数据0b10的十进制表示为:" + 0b10);System.out.println("八进制数据010的十进制表示为:" + 010);System.out.println("十六进制数据0x10的十进制表示为:" + 0x10);}
}

1.2 任意进制到十进制的转换

在这里插入图片描述

1.3 进制转换-十进制到任意进制转换

1.3.1 : 十进制到二进制的转换

公式:除基取余使用源数据,不断的除以基数(几进制,基数就是几)得到余数,直到商为0,再将余数倒着拼起来即可。

需求:将十进制数字11,转换为2进制。
实现方式:源数据为11,使用11不断的除以基数,也就是2,直到商为0。
在这里插入图片描述

1.3.2 : 十进制到十六进制的转换

公式:除基取余使用源数据,不断的除以基数(几进制,基数就是几)得到余数,直到商为0,再将余数倒着拼起来即可。

需求:将十进制数字60,转换为16进制。

实现方式:源数据为60,使用60不断的除以基数,也就是16,直到商为0。
在这里插入图片描述
结论:十进制到任意进制的转换

公式:除基取余使用源数据,不断的除以基数(几进制,基数就是几)得到余数,直到商为0,再将余数倒着 拼起来即可

1.4 快速进制转换法

8421码:8421码又称BCD码,是BCD代码中最常用的一种BCD: (Binary-Coded Decimal‎) 二进制码十进制数在这种编码方式中,每一位二进制值的1都是代表一个固定数值,把每一位的1代表的十进制数加起来得到的结果就是它所代表的十进制数。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.5 原码反码补码

前言 : 计算机中的数据,都是以二进制补码的形式在运算,而补码则是通过反码和原码推算出来的

原码 :(可直观看出数据大小)

就是二进制定点表示法,即最高位为符号位,【0】表示正,【1】表示负,其余位表示数值的大小。

通过一个字节表示+7和-7,代码:byte b1 = 7; byte b2 = -7;一个字节等于8个比特位,也就是8个二进制位

0(符号位) 0000111

1(符号位) 0000111

反码 : 正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。

补码 : (数据以该状态进行运算)正数的补码与其原码相同;负数的补码是在其反码的末位加1。

在这里插入图片描述

1.6 位运算-基本位运算符

   package com.test.demo;public class Demo2 {/*位运算:位运算符指的是二进制位的运算,先将十进制数转成二进制后再进行运算。在二进制位运算中,1表示true,0表示false。& 位与 : 遇false则false, 遇0则000000000 00000000 00000000 00000110     // 6的二进制&  00000000 00000000 00000000 00000010     // 2的二进制-----------------------------------------00000000 00000000 00000000 00000010     // 结果: 2| 位或 : 遇true则true, 遇1则1^ 位异或 : 相同为false, 不同为true~ 取反 : 全部取反, 0变1, 1变0  (也包括符号位)00000000 00000000 00000000 00000110         // 6的二进制补码~ 11111111 11111111 11111111 11111001-                                   1         // -1求反码------------------------------------11111111 11111111 11111111 11111000         // 反码推原码10000000 00000000 00000000 00000111         // -7*/public static void main(String[] args) {System.out.println(6 & 2);System.out.println(~6);}}

1.7 位运算-位移运算符

位运算概述 : 位运算符指的是二进制位的运算,先将十进制数转成二进制后再进行运算。在二进制位运算中,1表示true,0表示false。

位运算符介绍 :
在这里插入图片描述

代码 :

package com.test.demo;public class Demo3 {/*位移运算符:<< 有符号左移运算,二进制位向左移动, 左边符号位丢弃, 右边补齐0运算规律: 向左移动几位, 就是乘以2的几次幂12 << 2(0)0000000 00000000 00000000 000011000  // 12的二进制----------------------------------------------------------------------------->> 有符号右移运算,二进制位向右移动, 使用符号位进行补位运算规律: 向右移动几位, 就是除以2的几次幂000000000 00000000 00000000 0000001(1)  // 3的二进制----------------------------------------------------------------------------->>> 无符号右移运算符,  无论符号位是0还是1,都补0010000000 00000000 00000000 00000110  // -6的二进制*/public static void main(String[] args) {System.out.println(12 << 1);  // 24System.out.println(12 << 2);  // 48}
}
package com.test.demo;public class Demo4 {/*^ 运算符的特点一个数, 被另外一个数, 异或两次, 该数本身不变*/public static void main(String[] args) {System.out.println(10 ^ 5 ^ 10);}
}

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

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

嵌入式软件和硬件首先说一下怎么入门?

1&#xff0c;编程。这个你是否懂C语言编程&#xff0c;能够熟练或者熟悉使用C语言编写一段程序。不懂学习C语言。 2&#xff0c;单片机。你是否了解什么是单片机&#xff0c;单片机是做什么的。不懂的话&#xff0c;最好先了解一下什么是单片机&#xff0c;看下书&#xff0c…

FFmpeg5.0源码阅读——av_interleaved_write_frame

摘要&#xff1a;本文主要详细描述FFmpeg中封装时写packet到媒体文件的函数av_interleaved_write_frame的实现。   关键字&#xff1a;av_interleaved_write_frame   读者须知&#xff1a;读者需要熟悉ffmpeg的基本使用。 1 基本调用流程 av_interleaved_write_frame的基本…

IT服务管理学习笔记<一>

### IT服务管理知识整理 ITSM 的核心思想是&#xff0c;IT 组织&#xff0c;不管它是企业内部的还是外部的&#xff0c;都是 IT 服务提供者&#xff0c;其 主要工作就是提供低成本、高质量的 IT 服务。 ITSM 的核心思想是&#xff0c;IT 组织&#xff0c;不管它是企业内部的还…

leetCode刷题记录3-面试经典150题

文章目录 不要摆&#xff0c;没事干就刷题&#xff0c;只有好处&#xff0c;没有坏处&#xff0c;实在不行&#xff0c;看看竞赛题面试经典 150 题80. 删除有序数组中的重复项 II189. 轮转数组122. 买卖股票的最佳时机 II 不要摆&#xff0c;没事干就刷题&#xff0c;只有好处&…

【学习笔记】[集训队互测 2018] 完美的队列

有点难&#x1f605; 考虑暴力做法的本质&#x1f914; 发现瓶颈在于找到所有的作用区间&#xff0c;观察性质发现作用的区间和之前队列中有多少元素是无关的 用分块优化之&#xff08;类似于 大步小步&#xff09;&#xff0c;可以做到 O ( n n log ⁡ n ) O(n\sqrt{n}\log…

27 用linprog、fmincon求 解线性规划问题(matlab程序)

1.简述 ① linprog函数&#xff1a; 求解线性规划问题&#xff0c;求目标函数的最小值&#xff0c; [x,y] linprog(c,A,b,Aeq,beq,lb,ub) 求最大值时&#xff0c;c加上负号&#xff1a;-c ② intlinprog函数&#xff1a; 求解混合整数线性规划问题&#xff0c; [x,y] intl…

剑指 Offer 38. 字符串的排列 / LeetCode 47. 全排列 II(回溯法)

题目&#xff1a; 链接&#xff1a;剑指 Offer 38. 字符串的排列 难度&#xff1a;中等 输入一个字符串&#xff0c;打印出该字符串中字符的所有排列。 你可以以任意顺序返回这个字符串数组&#xff0c;但里面不能有重复元素。 示例: 输入&#xff1a;s “abc” 输出&…

主成分分析PCA算法

Principal Components Analysis 这个协方差矩阵是一个nXn的&#xff0c;且是对称矩阵&#xff0c;就会有n个特征值λ和特征向量v&#xff0c;每个特征向量也是n维的。第一行特征向量v对应特征值λ1 。 D(yk)&#xff1a;表示主成分yk的方差。方差越大&#xff0c;说明携带的信…
推荐文章