热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

详解IDEA中Debug的使用和进制转换问题

这篇文章主要介绍了IDEA中Debug的使用和进制转换,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1.Debug模式

1.1 什么是Debug模式

是供程序员使用的程序调试工具,它可以用于查看程序的执行流程,也可以用于追踪程序执行过程来调试程序。

1.2 Debug介绍与操作流程

如何加断点

选择要设置断点的代码行,在行号的区域后面单击鼠标左键即可

如何运行加了断点的程序

在代码区域右键Debug执行

看哪里

看Debugger窗口

看Console窗口

点哪里

点Step Into (F7)这个箭头,也可以直接按F7

如何删除断点

选择要删除的断点,单击鼠标左键即可

如果是多个断点,可以每一个再点击一次。也可以一次性全部删除

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

2.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);
 }
}

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

在这里插入图片描述

在这里插入图片描述

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

​ 2.3.1 : 十进制到二进制的转换

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

​ 需求:将十进制数字11,转换为2进制。

​ 实现方式:源数据为11,使用11不断的除以基数,也就是2,直到商为0。

在这里插入图片描述

​ 2.3.2 : 十进制到十六进制的转换

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

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

​ 实现方式:源数据为60,使用60不断的除以基数,也就是16,直到商为0。

在这里插入图片描述

​ 结论:十进制到任意进制的转换

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

2.4 快速进制转换法

​ 8421码:

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

​ 在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.5 原码反码补码

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

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

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

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

0(符号位) 0000111

1(符号位) 0000111

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

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

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

2.6 位运算-基本位运算符

public class Demo2 {
 /*
  位运算:

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

    & 位与 : 遇false则false, 遇0则0

      00000000 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);
 }
}

2.7 位运算-位移运算符

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

位运算符介绍 : [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bjGD9ZTs-1606280432728)(.\img\1590937235620.png)]

代码 :

public class Demo3 {
 /*
  位移运算符:

    <<有符号左移运算,二进制位向左移动, 左边符号位丢弃, 右边补齐0
      运算规律: 向左移动几位, 就是乘以2的几次幂

        12 <<2

        (0)0000000 00000000 00000000 000011000 // 12的二进制

  -----------------------------------------------------------------------------
    >> 有符号右移运算,二进制位向右移动, 使用符号位进行补位
      运算规律: 向右移动几位, 就是除以2的几次幂

        000000000 00000000 00000000 0000001(1) // 3的二进制

  -----------------------------------------------------------------------------

    >>> 无符号右移运算符, 无论符号位是0还是1,都补0

        010000000 00000000 00000000 00000110 // -6的二进制

  */
 public static void main(String[] args) {
  System.out.println(12 <<1); // 24
  System.out.println(12 <<2); // 48

 }
}
public class Demo4 {
 /*
  ^ 运算符的特点

    一个数, 被另外一个数, 异或两次, 该数本身不变
  */
 public static void main(String[] args) {
  System.out.println(10 ^ 5 ^ 10);
 }
}

3.基础练习

3.1 数据交换

案例需求

&#8203; 已知两个整数变量a = 10,b = 20,使用程序实现这两个变量的数据交换
最终输出a = 20,b = 10;

代码实现

public class Test1 {
 /*
  需求:已知两个整数变量a = 10,b = 20,使用程序实现这两个变量的数据交换
  最终输出a = 20,b = 10;


  思路:
  1. 定义一个三方变量temp,将a原本记录的值,交给temp记录 (a的值,不会丢了)
  2. 使用 a 变量记录 b 的值,(第一步交换完毕,b的值也丢不了了)
  3. 使用 b 变量记录 temp的值,也就是a原本的值 (交换完毕)
  4. 输出 a 和 b 变量即可
  */
 /*
  动态初始化格式:

   数据类型[][] 变量名 = new 数据类型[m][n];
   m表示这个二维数组,可以存放多少个一维数组
   n表示每一个一维数组,可以存放多少个元素
  */
 public static void main(String[] args) {
  int a = 10;
  int b = 20;

  // 将a原本记录的值,交给temp记录 (a的值,不会丢了)
  int temp = a;
  // 用 a 变量记录 b 的值,(第一步交换完毕,b的值也丢不了了)
  a = b;
  // 使用 b 变量记录 temp的值,也就是a原本的值 (交换完毕)
  b = temp;

  // 输出 a 和 b 变量即可
  System.out.println("a=" + a);
  System.out.println("b=" + b);
 }
}

3.2 数组反转【应用】

案例需求 :

&#8203; 已知一个数组 arr = {19, 28, 37, 46, 50}; 用程序实现把数组中的元素值交换,

&#8203; 交换后的数组 arr = {50, 46, 37, 28, 19}; 并在控制台输出交换后的数组元素

实现步骤 :

1. 定义两个变量, start和end来表示开始和结束的指针.

确定交换条件, start

代码实现 :

public class Test2 {
 /*
  需求:已知一个数组 arr = {19, 28, 37, 46, 50}; 用程序实现把数组中的元素值交换,
   交换后的数组 arr = {50, 46, 37, 28, 19}; 并在控制台输出交换后的数组元素。

  步骤:
    1. 定义两个变量, start和end来表示开始和结束的指针.
    2. 确定交换条件, start 

3.3 二维数组概述

&#8203; 概述 : 二维数组也是一种容器,不同于一维数组,该容器存储的都是一维数组容器

3.4 二维数组动态初始化

动态初始化格式:

数据类型[][] 变量名 = new 数据类型[m][n];
m表示这个二维数组,可以存放多少个一维数组
n表示每一个一维数组,可以存放多少个元素

public class Demo1Array {
 /*
  动态初始化格式:

   数据类型[][] 变量名 = new 数据类型[m][n];
   m表示这个二维数组,可以存放多少个一维数组
   n表示每一个一维数组,可以存放多少个元素
  */
 public static void main(String[] args) {
  // 数据类型[][] 变量名 = new 数据类型[m][n];
  int[][] arr = new int[3][3];
  /*
   [[I@10f87f48

   @ : 分隔符
   10f87f48 : 十六进制内存地址
   I : 数组中存储的数据类型
   [[ : 几个中括号就代表的是几维数组
   */
  System.out.println(arr);

  /*
   二维数组存储一维数组的时候, 存储的是一维数组的内存地址
   */
  System.out.println(arr[0]);
  System.out.println(arr[1]);
  System.out.println(arr[2]);

  System.out.println(arr[0][0]);
  System.out.println(arr[1][1]);
  System.out.println(arr[2][2]);

  // 向二维数组中存储元素
  arr[0][0] = 11;
  arr[0][1] = 22;
  arr[0][2] = 33;

  arr[1][0] = 11;
  arr[1][1] = 22;
  arr[1][2] = 33;

  arr[2][0] = 11;
  arr[2][1] = 22;
  arr[2][2] = 33;

  // 从二维数组中取出元素并打印
  System.out.println(arr[0][0]);
  System.out.println(arr[0][1]);
  System.out.println(arr[0][2]);
  System.out.println(arr[1][0]);
  System.out.println(arr[1][1]);
  System.out.println(arr[1][2]);
  System.out.println(arr[2][0]);
  System.out.println(arr[2][1]);
  System.out.println(arr[2][2]);
 }
}

3.5 二维数组访问元素的细节问题

问题 : 二维数组中存储的是一维数组, 那能不能存入 [提前创建好的一维数组] 呢 &#63;

答 : 可以的

代码实现

public class Demo2Array {
 /*
  问题: 二维数组中存储的是一维数组, 那能不能存入 [提前创建好的一维数组] 呢 &#63;
  答 : 可以的
  */
 public static void main(String[] args) {
  int[] arr1 = {11,22,33};
  int[] arr2 = {44,55,66};
  int[] arr3 = {77,88,99,100};

  int[][] arr = new int[3][3];

  arr[2][3] = 100;

  arr[0] = arr1;
  arr[1] = arr2;
  arr[2] = arr3;

  System.out.println(arr[1][2]);
  System.out.println(arr[2][3]);
 }
}

3.6 二维数组静态初始化

**完整格式 :** 数据类型[][] 变量名 = new 数据类型[][]{ {元素1, 元素2...} , {元素1, 元素2...}

**简化格式 :**  数据类型[][] 变量名 = { {元素1, 元素2...} , {元素1, 元素2...} ...};

**代码实现 : **

public class Demo3Array {
 /*
  完整格式:数据类型[][] 变量名 = new 数据类型[][]{ {元素1, 元素2...} , {元素1, 元素2...} ...};

  简化格式: 数据类型[][] 变量名 = { {元素1, 元素2...} , {元素1, 元素2...} ...};
  */
 public static void main(String[] args) {
  int[] arr1 = {11,22,33};
  int[] arr2 = {44,55,66};

  int[][] arr = {{11,22,33}, {44,55,66}};
  System.out.println(arr[0][2]);

  int[][] array = {arr1,arr2};
  System.out.println(array[0][2]);
 }
}

3.7 二维数组遍历

需求 :

&#8203; 已知一个二维数组 arr = {{11, 22, 33}, {33, 44, 55}};

&#8203; 遍历该数组,取出所有元素并打印

步骤 :

1. 遍历二维数组,取出里面每一个一维数组
2. 在遍历的过程中,对每一个一维数组继续完成遍历,获取内部存储的每一个元素

代码实现 :

public class Test1 {
 /*
  需求:

   已知一个二维数组 arr = {{11, 22, 33}, {33, 44, 55}};
   遍历该数组,取出所有元素并打印

  步骤:
   1. 遍历二维数组,取出里面每一个一维数组
   2. 在遍历的过程中,对每一个一维数组继续完成遍历,获取内部存储的每一个元素
  */
 public static void main(String[] args) {
  int[][] arr = {{11, 22, 33}, {33, 44, 55}};

  // 1. 遍历二维数组,取出里面每一个一维数组
  for (int i = 0; i 

3.8 二维数组求和

需求 :

某公司季度和月份统计的数据如下:单位(万元)
第一季度:22,66,44
第二季度:77,33,88
第三季度:25,45,65
第四季度:11,66,99

步骤 :

定义求和变量,准备记录最终累加结果使用二维数组来存储数据,每个季度是一个一维数组,再将4个一维数组装起来遍历二维数组,获取所有元素,累加求和输出最终结果

代码实现 :

public class Test2 {
 /*
  需求:
   某公司季度和月份统计的数据如下:单位(万元)
   第一季度:22,66,44
   第二季度:77,33,88
   第三季度:25,45,65
   第四季度:11,66,99

  步骤:
   1. 定义求和变量,准备记录最终累加结果
   2. 使用二维数组来存储数据,每个季度是一个一维数组,再将4个一维数组装起来
   3. 遍历二维数组,获取所有元素,累加求和
   4. 输出最终结果
  */
 public static void main(String[] args) {
  // 1. 定义求和变量,准备记录最终累加结果
  int sum = 0;
  // 2. 使用二维数组来存储数据,每个季度是一个一维数组,再将4个一维数组装起来
  int[][] arr = { {22,66,44} , {77,33,88} , {25,45,65} , {11,66,99}};
  // 3. 遍历二维数组,获取所有元素,累加求和
  for (int i = 0; i 

个季度是一个一维数组,再将4个一维数组装起来
3. 遍历二维数组,获取所有元素,累加求和
4. 输出最终结果

*/
public static void main(String[] args) {
// 1. 定义求和变量,准备记录最终累加结果
int sum = 0;
// 2. 使用二维数组来存储数据,每个季度是一个一维数组,再将4个一维数组装起来
int[][] arr = { {22,66,44} , {77,33,88} , {25,45,65} , {11,66,99}};
// 3. 遍历二维数组,获取所有元素,累加求和
for (int i = 0; i 

到此这篇关于IDEA中Debug的使用和进制转换的文章就介绍到这了,更多相关IDEA使用Debug内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!


推荐阅读
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • docker增加restart=always, docker重启后自动启动容器的方法
    本文介绍了在运行docker容器时如何添加参数来保证每次docker服务重启后容器也自动重启的方法,以及如何使用命令来更新已启动的容器。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 处理docker容器时间和宿主机时间不一致问题的方法
    本文介绍了处理docker容器时间和宿主机时间不一致问题的方法,包括复制主机的localtime到容器、处理报错情况以及重启容器的步骤。通过这些方法,可以解决docker容器时间和宿主机时间不一致的问题。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 本文介绍了电流源并联合并的方法,以及谐振电路的原理。谐振电路具有很强的选频能力,通过将电感和电容连接在一起,电流和电压会产生震荡。谐振频率的大小取决于电感和电容的大小,而电路中的电阻会逐渐降低震荡的幅度。电阻和电容组成的电路中,当电容放完电后,电阻两端的电压为0,电流不再流过电容。然而,电感是一种特殊的器件,当有电流流过时,线圈会产生感应磁场,阻止电流的流动,从而使电流不会减小。 ... [详细]
  • 标题: ... [详细]
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • 本文介绍了在Docker容器技术中限制容器对CPU的使用的方法,包括使用-c参数设置容器的内存限额,以及通过设置工作线程数量来充分利用CPU资源。同时,还介绍了容器权重分配的情况,以及如何通过top命令查看容器在CPU资源紧张情况下的使用情况。 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • position属性absolute与relative的区别和用法详解
    本文详细解读了CSS中的position属性absolute和relative的区别和用法。通过解释绝对定位和相对定位的含义,以及配合TOP、RIGHT、BOTTOM、LEFT进行定位的方式,说明了它们的特性和能够实现的效果。同时指出了在网页居中时使用Absolute可能会出错的原因,即以浏览器左上角为原始点进行定位,不会随着分辨率的变化而变化位置。最后总结了一些使用这两个属性的技巧。 ... [详细]
author-avatar
疯狂人儿-
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有