两个int型和一个long型的转换:

long now=1368257088802L;        
         int low = (int) (0xFFFFFFFFL & now);    
        int    heigh = (int) ((0xFFFFFFFF00000000L & now) >> 32);        
        System.out.println("long转双int:"+heigh+","+low);

long lowL=low;
        long heighL=heigh;        
        long now2=    ((long)lowL & 0xFFFFFFFFl) + (((long)heighL << 32) & 0xFFFFFFFF00000000l);    
        System.out.println("双int转long:"+now2);
        
        System.out.println("now:"+now);
        ByteBuffer buffer= ByteBuffer.allocate(100);
        buffer.putLong(now);        
        buffer.flip();
        
        long three=buffer.getInt();
        long four=buffer.getInt();        
        System.out.println(three+","+four);
        long now3=(((three<<32)&0xFFFFFFFF00000000l)+(four& 0xFFFFFFFFl));
        System.out.println("高位+低位:"+now3);

Byte aa='\n';
        System.out.println(aa);
        
        int value=61156;
         ByteBuffer byte_buffer= ByteBuffer.allocate(4);        
         byte_buffer.putInt(value);
         byte_buffer.flip();
    
         byte  aa1=byte_buffer.get();        
         byte  aa2=byte_buffer.get();        
         byte  aa3=byte_buffer.get();//大于128的byte的补码为负值,小于128的byte为正值        
         byte  aa4=byte_buffer.get();        
         System.out.println(aa1+","+aa2+","+aa3+","+aa4);
        
         int test=0;
         test+=( aa1<<24 &0xFF000000);
         test+=(aa2<<16 &0xFF0000);
        // test+=(aa3<<8 & 0xFF00);//一直是正确的
        // test+=(aa3 & 0xFF)<<8;//一直是正确的
         test+=( aa3 <<8 );//当为负值时,是错误的;只有为正值是才是正确的
         test+=( aa4&0xFF)  ;
        
         System.out.println(test);
        
         //转换成二进制
         System.out.println( Integer.toBinaryString(aa4 ) +","+aa4  );
         System.out.println( Integer.toBinaryString(aa4 & 0xFF)+","+(aa4 & 0xFF)   );
        
         System.out.println("<---------------------分割线-------------------------->");
         int test_byte=129;
         byte byte_test=(byte)(test_byte);
         System.out.println( Integer.toBinaryString(byte_test ) +","+byte_test  );
         System.out.println( Integer.toBinaryString(byte_test & 0xFF)+","+(byte_test & 0xFF)   );
         int temp=1;
         if((byte_test & temp)>0)
         {
             System.out.println("---");
         }
        
        
         System.out.println("<---------------------分割线-------------------------->");
         int a_255=128;
         byte test_1=(byte)(a_255);
         System.out.println("a_255:"+(test_1 &0xFF) );
         System.out.println("a_255:"+(test_1 ) );

个人备注:转换后的二进制的表示数值的有效位是一样的,高位是补码的填充。

java中关于二进制的初步。的更多相关文章

  1. Java中的二进制及基本的位运算

    Java中的二进制及基本的位运算 二进制是计算技术中广泛采用的一种数制.二进制数据是用0和1两个数码来表示的数.它的基数为2,进位规则是"逢二进一",借位规则是"借一当二 ...

  2. java中的二进制

    (1)按位与运算 & 1 & 1 = 1, 0 & 1 = 0 51 & 5  即 0011  0011 & 0000  0101 =0000 0001 = 1 ...

  3. 在Java中关于二进制、八进制、十六进制的辨析

    八进制数中不可能出7以上的阿拉伯数字.但如果这个数是123.是567,或12345670,那么它是八进制数还是10进制数?单从数字的角度来讲都有可能! 八进制 所以在Java中规定,一个数如果要指明它 ...

  4. Java中处理二进制移位

    我相信,这篇文章读起来会相当有趣. 文章中编程语言是Java,用Java的原因:第一,Java不做数据溢出校验,这样我们可以忽略溢出异常:第二,Java普及率比较高,就像是python或shell,几 ...

  5. java中表示二进制、八进制、十进制、十六进制,double、float、整型

    java里不能这样表示二进制,只能是   8,10,16进制  8:         前置   0  10:      不需前置 16:      前置   0x   或者   0X double:2 ...

  6. 我的Android进阶之旅------>对Java中注释/**@hide*/的初步认识

    今天写一个调节系统背光亮度的时候,参考了Android中的Setting源码,在源码中有这么一段代码: private static final int MAXIMUM_BACKLIGHT = and ...

  7. java中表示二进制、八进制、十进制、十六进制

    1.进制 进制是一种记数方式 ,可以用有限的数字符号代表所有的数值.由特定的数值组成. 2.进制的表现形式 二进制: 由0和1两个数字组成. 八进制: 由0-7数字组成,为了区分与其他进制的数字区别, ...

  8. java中使用二进制进行权限控制

    基本概念 package test; publicclass Rights { publicstaticvoid main(String[] args) { int a=1; // 001 状态a i ...

  9. Java中转换为二进制的几种实现

    public class HexUtil { private static final String[] DIGITS_UPPER = {"0", "1", & ...

随机推荐

  1. django中templates阅读笔记

    一.基本知识 1.模版是独立于django的,可以独立运行. 模版变量是用两个大括号括起来的字符串,表示变量.例如{{ person_name }} 模版标签,是用一对大括号和一对百分号括起来的,例如 ...

  2. 如何发布Node模块到NPM社区

    “学骑自行车最快的方式就是先骑上去” 一.安装node和npm 1.一种是通过编译node源文件安装node(注意:需要Python 2.6或2.7已经安装) $ wget http://nodejs ...

  3. 用 Qt 中的 QDomDocument类 处理 XML 文件

    XML,全称为 “可扩展标记语言”(extensible markup language).是一种非常方便的数据交换与数据存储的工具. 我们在取得一个XML格式的文件后,需要作句法分析去提取发布方提供 ...

  4. Linux C语言小程序

    Linux C语言小程序 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include & ...

  5. Xilinx ISE Design Suite 14.7 ISim 简单仿真

    1.创建完项目(以Xilinx ISE Design Suite 14.7开发流程的例子    led例子   为例),编译通过,我们就可以对这个项目进行仿真: 2.然后切换到simulation,然 ...

  6. angular学习笔记(二十二)-$http.post

    基本语法: $http.post('url',{},{}).success(function(data,status,headers,config){ }).error(function(data,s ...

  7. C++虚函数表与虚析构函数

    1.静态联编和动态联编联编:将源代码中的函数调用解释为要执行函数代码. 静态联编:编译时能确定唯一函数.在C中,每个函数名都能确定唯一的函数代码.在C++中,因为有函数重载,编译器须根据函数名,参数才 ...

  8. 使用codedom 编写脚本解释器

    本篇博客的目的是为了保存例子,怕自己忘记. private void dd(string code) { string path = "BonkerSpace"; if (File ...

  9. sql server 递归汇总 按指定层级汇总

    每个地区递归层级可能不一致,数据表(table)存放最小层级地区 area --地区层级表 id name f_id leve 1 中国 0 1 2 湖北 1 2 3 武汉 2 3 ... --测试数 ...

  10. python URLObject url处理模块

    1.需求来源 给一个url串,例如https://github.com/zacharyvoase/urlobject?spam=eggs#foo,想要截取串中某个部分,比如传输协议(https).服务 ...