先看打印结果在看代码比较好理解。结果在最下面的位置。

总结:讲解了二进制的按位异域、按位与、左移的运算规则。并通过次3种算法得到2个数相加的结果。二进制应该还有其他算法,由于知识浅薄就不知道了。

代码:

 public static void main(String[] args){
int a=11,b=9;//初始化要执行加法的值
System.out.println("===开始二进制运算===");
add(a,b);
System.out.println("===二进制运算结束==="); } /**
* 将二进制的数据打印出来
* @param binars 需要打印的二进制值
* @param paramName 需要打印的参数名称
* @return 返回打印的字符串
*/
public static String printBnary(StringBuilder binars,int param){
StringBuilder binarsRe=new StringBuilder();
String[] strs=binars.toString().split(",");
int strLength=strs.length;
while (strLength>=1){ binarsRe.append(strs[strLength-1]+" ");
strLength--;
}
return binarsRe.toString();
} /**
* 十进制转换为二进制输出
* @param a 要转换的十进制数
* @param binars 接收转换后的二进制数据
* @param paramName 需要打印的参数名称
* @return
*/
public static String DecimalTransBinary(int a,StringBuilder binars,int param){
int rem=a%2;//取余数
int base=a/2;//取基数
/**
* 物流是余数和基数都必须除尽为0
*/
if(base>0 || rem>0){
//将所有的余数都添加到字符串中使用,隔开在打印是使用
binars.append(rem+",");
DecimalTransBinary(base,binars,param);
}
//十进制转换二进制成功后,将二进制数据打印出来
return printBnary(binars,param); } /**
* 十进制加法,解释如何使用二进制实现的
* @param a 执行加法的参数
* @param b 执行加法的参数
* @return 返回加法成功后的整数
*/
public static int add(int a,int b){ //对需要相加的数据输出为二进制
StringBuilder binars=new StringBuilder();
String aStr=DecimalTransBinary(a,binars,a); //将stringBuilder数据输出到控制台
binars.setLength(0);
String bStr=DecimalTransBinary(b,binars,b); int res=a;
//按为异域的二进制运算
int xor=a^b;
System.out.println("");
System.out.println("按位异域(^):二进制数据的相同位不同则为1,相同则为0。");
System.out.println(a+"的二进制值:"+aStr);
System.out.println(b+"的二进制值:"+bStr);
System.out.println("参数:"+a+" 参数:"+b+" 进行"+a+"^"+b+":");
binars.setLength(0);
String xorStr=DecimalTransBinary(xor,binars,xor);
System.out.println(aStr+"^"+bStr+"="+xorStr);
System.out.println("按位异域后得到的二进制值:"+xorStr);
System.out.println("按位异域后得到的十进制值:"+xor);
//按位与的二进制运算和左移一位的值
int forward=(a&b)<<1;
System.out.println();
System.out.println("按位与(&):二进制数据的相同位都为1则为1,若有一个不为1则为0。");
System.out.println("左移(<<):二进制数据左移b为(在后面添加b个0)。例如:11<<1。11的二进制为1011,左移1为就是10110;");
System.out.println("10110转换为十进制就是:22。左移用十进制解释就是,11乘以2的1次方的结果。11<<2就是11乘以2的次方的结果。");
System.out.println("参数:"+a+" 参数:"+b+" 进行("+a+"&"+b+")<<1:");
binars.setLength(0);
String forwardStr=DecimalTransBinary(forward,binars,forward);
System.out.println("("+aStr+"&"+bStr+")<<1="+forwardStr);
System.out.println("按位与后得到的二进制值:"+forwardStr);
System.out.println("按位与后得到的十进制值:"+forward);
System.out.println();
if(forward!=0){
System.out.print("("+a+"&"+b+")<<1="+forward+"运算结果不为0,");
System.out.println("将"+a+"^"+b+"运算的结果值:"+xor+";("+a+"&"+b+")<<1运算的结果值:"+forward+"。继续重复以上运算。");
res=add(xor,forward);
}else{
System.out.println("("+a+"&"+b+")<<1="+forward+"运算结果为0;"+a+"^"+b+"按位异域的运算结果就是最终的和:"+xor);
res=xor;
} return res;
}

  

结果:

===开始二进制运算===

按位异域(^):二进制数据的相同位不同则为1,相同则为0。

11的二进制值:1 0 1 1

9的二进制值:1 0 0 1

参数:11 参数:9  进行11^9:

1 0 1 1 ^1 0 0 1 =1 0

按位异域后得到的二进制值:1 0

按位异域后得到的十进制值:2

按位与(&):二进制数据的相同位都为1则为1,若有一个不为1则为0。

左移(<<):二进制数据左移b为(在后面添加b个0)。例如:11<<1。11的二进制为1011,左移1为就是10110;

10110转换为十进制就是:22。左移用十进制解释就是,11乘以2的1次方的结果。11<<2就是11乘以2的次方的结果。

参数:11 参数:9  进行(11&9)<<1:

(1 0 1 1 &1 0 0 1 )<<1=1 0 0 1 0

按位与后得到的二进制值:1 0 0 1 0

按位与后得到的十进制值:18

(11&9)<<1=18运算结果不为0,将11^9运算的结果值:2;(11&9)<<1运算的结果值:18。继续重复以上运算。

按位异域(^):二进制数据的相同位不同则为1,相同则为0。

2的二进制值:1 0

18的二进制值:1 0 0 1 0

参数:2 参数:18  进行2^18:

1 0 ^1 0 0 1 0 =1 0 0 0 0

按位异域后得到的二进制值:1 0 0 0 0

按位异域后得到的十进制值:16

按位与(&):二进制数据的相同位都为1则为1,若有一个不为1则为0。

左移(<<):二进制数据左移b为(在后面添加b个0)。例如:11<<1。11的二进制为1011,左移1为就是10110;

10110转换为十进制就是:22。左移用十进制解释就是,11乘以2的1次方的结果。11<<2就是11乘以2的次方的结果。

参数:2 参数:18  进行(2&18)<<1:

(1 0 &1 0 0 1 0 )<<1=1 0 0

按位与后得到的二进制值:1 0 0

按位与后得到的十进制值:4

(2&18)<<1=4运算结果不为0,将2^18运算的结果值:16;(2&18)<<1运算的结果值:4。继续重复以上运算。

按位异域(^):二进制数据的相同位不同则为1,相同则为0。

16的二进制值:1 0 0 0 0

4的二进制值:1 0 0

参数:16 参数:4  进行16^4:

1 0 0 0 0 ^1 0 0 =1 0 1 0 0

按位异域后得到的二进制值:1 0 1 0 0

按位异域后得到的十进制值:20

按位与(&):二进制数据的相同位都为1则为1,若有一个不为1则为0。

左移(<<):二进制数据左移b为(在后面添加b个0)。例如:11<<1。11的二进制为1011,左移1为就是10110;

10110转换为十进制就是:22。左移用十进制解释就是,11乘以2的1次方的结果。11<<2就是11乘以2的次方的结果。

参数:16 参数:4  进行(16&4)<<1:

(1 0 0 0 0 &1 0 0 )<<1=

按位与后得到的二进制值:

按位与后得到的十进制值:0

(16&4)<<1=0运算结果为0;16^4按位异域的运算结果就是最终的和:20

===二进制运算结束===

java实现二进制的加法的更多相关文章

  1. Java基础-二进制以及字符编码简介

    Java基础-二进制以及字符编码简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 想必计算机毕业的小伙伴或是从事IT的技术人员都知道数据存储都是以二进制的数字存储到硬盘的.从事开 ...

  2. java 位运算符 以及加法 交换两个变量值

    先给出十转二的除法 2       60 30       0 15 0 7 1 3 1 1  1 0  1 60转二 111100 再介绍位运算符 a=60 b=13 A = 0011 1100 B ...

  3. java基础 二进制补码

    二进制补码: 1.计算机系统的内部以二进制形式存储数据. 2.在Java程序中输入的十进制的数据都会被自动转换为二进制,Java内部也以二进制来进行数值运算,但返回的结果是十进制. 二进制补码的原理: ...

  4. java:判断二进制数据中第n位是否为1

    可以使用位运算来判断. &是位的与运算符,是指二进制数按位“与”的操作, 逻辑与就是两者都为真的时候才为真,其他真假,假真,假假的运算结果都是假.二进制写法如下 1 & 1 = 1 , ...

  5. Java:二进制(原码、反码、补码)与位运算

    一.二进制(原码.反码.补码) 二进制的最高位是符号位(“0”代表正数,“1”代表负数): Java中没有无符号数: 计算机以整数的补码进行运算: 1.  原码:将一个整数转换成二进制表示 以 int ...

  6. java图片二进制相互转换

    import java.awt.image.BufferedImage; import java.io.ByteArrayInputStream; import java.io.ByteArrayOu ...

  7. java中 二进制 八进制 十六进制 十进制 相互转换 最简方法

    package com.swift; import java.util.Scanner; public class Hex2Decimal { public static void main(Stri ...

  8. Java中二进制字节与十六进制互转

    在Java中字节与十六进制的相互转换主要思想有两点: 1.二进制字节转十六进制时,将字节高位与0xF0做"&"操作,然后再左移4位,得到字节高位的十六进制A;将字节低位与0 ...

  9. Java读写二进制数据

    import java.io.*; import java.time.LocalDate; public class Test { public static void main(String[] a ...

随机推荐

  1. hihoCoder 1549 或运算和

    #1549 : 或运算和 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定N个数A1...AN (0 <= Ai < 220) 和一个正整数K,我们用An ...

  2. golang 模板(template)的常用基本语法

    1. 模板 在写动态页面的网站的时候,我们常常将不变的部分提出成为模板,可变部分通过后端程序的渲染来生成动态网页,golang提供了html/template包来支持模板渲染. 这篇文章不讨论gola ...

  3. GBK和UTF-8文字编码的区别

    UTF-8是一种国际化标准的文字编码,我们已知Windows系统程序已经将最初的UTF-8转向Unicode,而GBK的存在是为了中国国情而创造的,不过GBK也将伴随着中文字符的一直流传下去. GBK ...

  4. python函数回顾:dict()

    描述 dict() 函数用于创建一个字典. 语法 dict 语法: class dict(**kwarg) class dict(mapping, **kwarg) class dict(iterab ...

  5. 浅析TCP/IP

    TCP/IP概述 TCP/IP起源于1969年美国国防部(DOD:The United States Department Of Defense)高级研究项目管理局(APRA:AdvancedRese ...

  6. 理解是最好的记忆方法 之 CSS中a链接的4个伪类为何有顺序

    在CSS中,a标签有4种伪类,分别为: a:link, a:visited, a:hover, a:active 对其稍有了解的前端er都知道,4个伪类是有固定顺序的(LVHA),否则很容易出现预期之 ...

  7. MySQL 第四天

    回顾 列属性: 主键, 自增长, 唯一键     关系: 一对一,一对多和多对多 范式: 三层范式 1NF: 字段设计必须符合原子性 2NF: 不存在部分依赖(没有复合主键) 3NF: 不存在传递依赖 ...

  8. (4.19)深入理解SQLSERVER的日志链

    您真的理解了SQLSERVER的日志链了吗? 转自:https://www.cnblogs.com/lyhabc/p/3460272.html 先感谢宋沄剑给本人指点迷津,还有郭忠辉童鞋今天在QQ群里 ...

  9. 自定义gradle plugin

    最近开始接触gradle 正好有个需求apidoc

  10. python常用模块——random模块

    参考博客:http://www.360doc.com/content/14/0430/11/16044571_373443266.shtml 今天突然想起python该怎么生成随机数?查了一下,贴出实 ...