算法学习01 — Java 底层的正整数与负整数

本节课学到的知识

  1. 编写一个方法,打印出 int 类型数字的二进制长什么样

  2. 为什么 int 类型的最大值是 2^32 - 1,最小值是 -2^32

  3. 负整数的二进制如何进行计算,为什么?

打印 int 数字的二进制

    public void printBinary(int num) {
for (int i = 31; i >= 0; i--) {
System.out.print((num & (1<<i)) == 0 ? 0 : 1);
}
System.out.println();
}

为什么 int 类型的最大值是 2^31 - 1,最小值是 -2^31

int 占用 4 个字节, 32 位二进制位;

二进制中的最左边一位用于表示正负符号位,0 表示正数,1表示负数;

所以,只能是 2^31,而不能是 2^32;

同时 0 的二进制是 00000000000000000000000000000000,也就是说,0 在二进制中属于正数,所以正整数是 2^31 - 1;

负整数的二进制如何进行计算,为什么

首先使用上面的 printBinary 方法打印一下 -1 的二进制数:

// 与想象中的 10000000000000000000000000000001 不一样;
11111111111111111111111111111111

因为 Java 底层设计负数的计算方式为:

(1)判断:如果最左边一位是 1,那么表示该数是负数,之后符号位也参与到位运算当中;

(2)对所有 32 位进行取反运算,得出:00000000000000000000000000000000;

(3)然后做 + 1 操作,得出:00000000000000000000000000000001;

(4)最后得出,11111111111111111111111111111111 表示 -1;

那么,为什么要使用这么膈应的方式进行计算呢?

因为如果不这样实现,使用二进制的位运算去实现加减乘除的时候,就需要进行适配了;

说白了,使用 10000000000000000000000000000001 这种样式表示 -1,实现加减乘除的算法时;

正数的底层实现逻辑和负数的将会不一样,为了保证不管是正数还是负数,底层的实现方式、实现逻辑都是一样的,

就需要二进制取反加 1 的方式来表示负数!

如果全部是 1 表示 -1,最小的 int 值怎么表示呢?

    @Test
public void test() {
int min = Integer.MIN_VALUE;
printBinary(min);
int max = Integer.MAX_VALUE;
printBinary(max);
} public void printBinary(int num) {
for (int i = 31; i >= 0; i--) {
System.out.print((num & (1<<i)) == 0 ? 0 : 1);
}
System.out.println();
} 结果:
10000000000000000000000000000000
01111111111111111111111111111111

咱们使用取反加 1 的方式进行反推一下:

10000000000000000000000000000000 取反:01111111111111111111111111111111;

此时,我们发现 01111111111111111111111111111111 就是 Integer.MAX_VALUE 的二进制数;

01111111111111111111111111111111 加 1:10000000000000000000000000000000

哎嘿!又回到了最开始的样子,这也说明了 int 类型的最大值是 2^31 - 1,最小值是 -2^31;

算法学习01—Java底层的正整数与负整数的更多相关文章

  1. 一致性哈希算法学习及JAVA代码实现分析

    1,对于待存储的海量数据,如何将它们分配到各个机器中去?---数据分片与路由 当数据量很大时,通过改善单机硬件资源的纵向扩充方式来存储数据变得越来越不适用,而通过增加机器数目来获得水平横向扩展的方式则 ...

  2. Java虚拟机JVM学习01 流程概述

    Java虚拟机JVM学习01 流程概述 Java虚拟机与程序的生命周期 一个运行时的Java虚拟机(JVM)负责运行一个Java程序. 当启动一个Java程序时,一个虚拟机实例诞生:当程序关闭退出,这 ...

  3. Java学习01

    Java学习01 第一章 1.JRE与JDK JDK(JAVA Develop Kit,JAVA开发工具包)提供了Java的开发环境和运行环境,主要用于开发JAVA程序,面向Java程序的开发者; J ...

  4. java底层学习

    额,马上就要面试了,Java的底层肯定是需要了解的.网上找了找java的底层文章,做个记号.java底层主要是类的加载.连接和初始化. 本文主要分为四个方面: (1)java底层概述 (2)new和n ...

  5. Java底层知识学习:Bytecode and JMM

    最近在跟着耗子哥的程序员练级指南学习Java底层知识,结合<深入理解Java虚拟机>这本书在看,写笔记,看资料,成长中…… 目前看完了第二章JMM和各内存区OOM的情况 一篇图文并茂介绍字 ...

  6. Java实现 蓝桥杯 算法提高 01背包

    算法提高 01背包 时间限制:1.0s 内存限制:256.0MB 问题描述 给定N个物品,每个物品有一个重量W和一个价值V.你有一个能装M重量的背包.问怎么装使得所装价值最大.每个物品只有一个. 输入 ...

  7. Java企业实训 - 01 - Java前奏

    前言: 虽然个人专攻.NET方向,不过由于个人是干教育行业的,方方面面的东西,不能说都必须精通,但肯定多少都会涉及到. 一个菜鸟学员,从啥都不会,经过一步步学习,最后到企业上手掌管一个模块甚至一个项目 ...

  8. java虚拟机学习-触摸java常量池(13-1)

    java虚拟机学习-深入理解JVM(1) java虚拟机学习-慢慢琢磨JVM(2) java虚拟机学习-慢慢琢磨JVM(2-1)ClassLoader的工作机制 java虚拟机学习-JVM内存管理:深 ...

  9. LeetCode初级算法--动态规划01:爬楼梯

    LeetCode初级算法--动态规划01:爬楼梯 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net ...

  10. LeetCode初级算法--其他01:位1的个数

    LeetCode初级算法--其他01:位1的个数 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net ...

随机推荐

  1. stream 链式结构 求和

    Double aDouble = Optional.ofNullable(wayfairMonthBill.getPaymentAmountDetailJson()) .filter(StringUt ...

  2. 35.Linux 性能监控常用命令

    内存 top CPU yum install -y sysstat mpstat 网络 netstat //参数说明 //-n:拒绝显示别卖,能显示数字的全部转化数字 //-l:仅列出Listen(监 ...

  3. P1982 [NOIP2013 普及组] 小朋友的数字 题解

    目录 简单版 题目 code 本题 code 简单版 先要会做这道题 题目 P1115 最大子段和https://www.luogu.com.cn/problem/P1115 这道题其实是动态规划,d ...

  4. Mysql数据库基础第二章:(八)子查询经典案例

    Mysql数据库基础系列 软件下载地址 提取码:7v7u 数据下载地址 提取码:e6p9 mysql数据库基础第一章:(一)数据库基本概念 mysql数据库基础第一章:(二)mysql环境搭建 mys ...

  5. Android开发数据库Sqlite

    创建数据库 首先我们要了解这个类:SQLiteOpenHelper: 1.写一个类继承SQLiteOpenHelper 2.实现里面的方法,创建构造方法 参数解释: /** @param: conte ...

  6. CSS3-transform位移实现双开门效果

    transform可以用于实现位移,旋转,缩放等效果. 位移:transform: translate(水平距离,垂直距离); 这里先借助其位移属性实现双开门的效果,鼠标hover的时候最上面的图片向 ...

  7. libev中的gcc内嵌函数

    在学习libev的过程中,遇到了大量的gcc内嵌函数,大多是为了提升性能而使用的,这里做一个汇总和介绍,并会持续更新 1.__builtin_expect:该函数是gcc引入的,为的是让程序员讲最有可 ...

  8. Django 介绍及环境准备

    Django介绍: Django(发音:[`dʒæŋɡəʊ])是基于Python的Web框架,它是开源的,免费的. Django使构建更好的web应用程序变得更容易.更快.代码更少 django的MT ...

  9. 使用git钩子防止合并分支

    git是一款实用的版本管理工具,我们通过git init初始化一个git仓库,git会在当前目录为我们生成一个.git/目录,用来管理我们的版本文件信息. 在这个目录中有一个二级目录.git/hook ...

  10. Jmeter五、jmeter中的逻辑控制器

    1.simple controller 提供一个块的结构和控制.更方便,更清晰. 嵌套其他的controller 2.loop controller 循环控制器 控制循环次数 可以使用变量 ${__t ...