进制的底层逻辑规则 左移<< 右移>> 取反加一 补位原则 正负数 相反数等 文章中含验证源码

简介: 进制的底层逻辑规则 左移<< 右移>> 取反加一 补位原则 正负数 相反数等 文章中含验证源码
package cn.Text;
public class text1 {
    public static void main(String[] args) {
        int num=888;
        print(num);
        //测试   左移      二进制数:00000000000000000000000000000010          2
        int test=1;
        print(test);
        print(test<<1);
        print(test<<2);
        print(test<<8);
        //测试  右移
        System.out.println("********");
        int e=1024;
        int f=Integer.MIN_VALUE;
        print(e);
        print(f);    //   10000000000000000000000000000000
        print(e>>1);
        print(f>>2);//    11000000000000000000000000000000     TODO   >>   符号位 “1”  来补
        print(f>>>1);//   01000000000000000000000000000000     TODO   >>>   "0"  来补
        // TODO  -2^31 ~ 2^31 -1
        int a=Integer.MAX_VALUE;
        int b=Integer.MIN_VALUE;
        System.out.println(a);
        System.out.println(b);
        print(a);
        //    -3   -5二进制数
        //    TODO     负数,第一位是符号位  32位  10000......000  表示负数,取反加1
        print(-3);    //11111111111111111111111111111101   TODO  符号位不变,其余取反  00000000000000000000000000000010  加1  00000000000000000000000000000011
        print(-5);    //11111111111111111111111111111011
        //放飞自我
        int c=21183578;
        int d=999834;
        print(c);
        print(d);
        System.out.println("=============");
        print(c|d);
        print(c&d);
        print(c^d);
        //相反数
        int g=5;
        int h=-g;
        int k=(~g+1);
        System.out.println(g);
        System.out.println(h);
        System.out.println(k);
    }
    public static void print(int num){
        for (int i = 31; i >=0; i--) {
            System.out.print((num&(1<<i))==0?"0":"1");
        }
        System.out.println();
    }
}
"C:\Program Files\Java\jdk1.8.0_181\bin\java.exe" "-javaagent:S:\jdk\IntelliJ IDEA Community Edition 2021.3\lib\idea_rt.jar=52057:S:\jdk\IntelliJ IDEA Community Edition 2021.3\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_181\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_181\jre\lib\rt.jar;C:\Users\17331\IdeaProjects\order\out\production\order" cn.Text.text1
00000000000000000000001101111000
00000000000000000000000000000001
00000000000000000000000000000010
00000000000000000000000000000100
00000000000000000000000100000000
********
00000000000000000000010000000000
10000000000000000000000000000000
00000000000000000000001000000000
11100000000000000000000000000000
01000000000000000000000000000000
2147483647
-2147483648
01111111111111111111111111111111
11111111111111111111111111111101
11111111111111111111111111111011
00000001010000110011110001011010
00000000000011110100000110011010
=============
00000001010011110111110111011010
00000000000000110000000000011010
00000001010011000111110111000000
5
-5
-5
Process finished with exit code 0

image.png

上面是java的,下面是python的,代码执行不一样,理论一样image.png

目录
相关文章
|
3月前
|
C# 图形学
小功能⭐️C#控制小数点后位数的方法
小功能⭐️C#控制小数点后位数的方法
|
5月前
|
Java
JAVA工具类匹配重复或者连续的字符和符号
JAVA工具类匹配重复或者连续的字符和符号
|
11月前
|
存储 C#
C# 逻辑位运符及运算原理 按位操作二进制
C# 逻辑位运符及运算原理 按位操作二进制
|
6月前
|
自然语言处理 IDE 测试技术
测试左移的方法
测试左移的方法
|
6月前
|
测试技术
leetcode-241:为运算表达式设计优先级
leetcode-241:为运算表达式设计优先级
33 0
|
运维 Shell Perl
【运维知识高级篇】超详细的Shell编程讲解2(变量切片+统计变量长度+字串删除+字串替换+七种方法进行数值运算+整数比较+多整数比较+文件判断+字符串比对+正则比对+配合三剑客的高阶用法)(二)
【运维知识高级篇】超详细的Shell编程讲解2(变量切片+统计变量长度+字串删除+字串替换+七种方法进行数值运算+整数比较+多整数比较+文件判断+字符串比对+正则比对+配合三剑客的高阶用法)(二)
131 0
算数右移和逻辑右移的区别及逻辑运算的窍门
算数右移和逻辑右移的区别及逻辑运算的窍门
710 0
【每日一题Day41】生成交替二进制字符串的最小操作数 | 模拟 位运算
思路:长度一定的交替二进制字符串有两种可能性,以字符0开头的0101字符串和以字符1开头的1010字符串,因此只需要将字符串s与这两种字符串进行比较,记录不相同的字符个数,最后返回较小值即可
97 0
【每日一题Day41】生成交替二进制字符串的最小操作数 | 模拟 位运算
代码例题(1-3)(含进阶版)及讲解:1.求两个数二进制中不同位的个数 2.打印整数的二进制的奇数和偶数位 3.交换两个变量,不创建临时变量 (ps最后一道为已知代码求值题)
代码例题(1-3)(含进阶版)及讲解:1.求两个数二进制中不同位的个数 2.打印整数的二进制的奇数和偶数位 3.交换两个变量,不创建临时变量 (ps最后一道为已知代码求值题)
95 0
7-31 字符串循环左移 (20 分)
7-31 字符串循环左移 (20 分)
104 0