一、需求:

最近在做文件传输的东西,文件传输当然是传输很重要,包括编码格式以及进制的统一。

简略的说一下这次做的东西:首先文件是按照块来发送的,一块一块大的发,但是,发送的过程是这样的;

先发送头部,头部包括三部分:1.一个int类型的文件Id,

              2.一个long类型的偏移量,因为是块发,当然需要知道每次发送的起始位置。

              3.一个int类型的文件长度。

而我们知道,文件传输可以是文件流的形式。但是是以二进制传输的,所以就牵扯到了int<->二进制和long<->二进制的需求。

二、具体的代码实现:

 package com.xupt.until;

 public class ByteAndString {

     private static final String hex = "0123456789ABCDEF";  //字符串将由下面找到的对应

     public static String toHex(byte[] buffer) {  //类型为byte的数组 有下标
StringBuffer result = new StringBuffer(); for(int i = 0;i < buffer.length;i++) {
byte bv = buffer[i];
result.append(i == 0 ? "" : ' ')
/* 这个方法将二进制的形式转换成字符串的“十六进制”。这是前四位
右移四位后变成后四位,对应的数字找hex(用下标找)。
比如:
1010 0010 对应的是先右移四位1010到后四位,与00FF相与就是
0000 0000 0000 1010与0000 0000 1111 1111相与是1010对应十进制是10在hex中找
因此它是A
*/
.append(hex.charAt((bv >> 4) & 0x0F))
/*这是后四位和上面的过程一样,只是不用移位*/
.append(hex.charAt(bv & 0x0F));
}
return result.toString();
} //这是将int类型得转化成二进制类型的,高低低高的形式
public static void setIntAt(byte[] buffer,int offset,int value) {
//int是4字节的,即有32位,八位八位一处理。
//int类型的前八位即高位先右移到最后八位即低位和00FF相与得到其本身的放进buffer的0为即低位,高低
buffer[offset + 0] = (byte) ((value >> 24) & 0x00FF);
buffer[offset + 1] = (byte) ((value >> 16) & 0x00FF);
buffer[offset + 2] = (byte) ((value >> 8) & 0x00FF);
buffer[offset + 3] = (byte) (value & 0x00FF);
} //这是将long的类型转化成二进制的方法
public static void setLongAt(byte[] buffer,int offset,long value) {
//long是8字节的,即有64位,八位八位一处理。
//long类型的前八位即高位先右移到最后八位即低位和00FF相与得到其本身的放进buffer的0为即低位,高低
buffer[offset + 0] = (byte) ((value >> 56) & 0x00FF);
buffer[offset + 1] = (byte) ((value >> 48) & 0x00FF);
buffer[offset + 2] = (byte) ((value >> 40) & 0x00FF);
buffer[offset + 3] = (byte) ((value >> 32) & 0x00FF);
buffer[offset + 4] = (byte) ((value >> 24) & 0x00FF);
buffer[offset + 5] = (byte) ((value >> 16) & 0x00FF);
buffer[offset + 6] = (byte) ((value >> 8) & 0x00FF);
buffer[offset + 7] = (byte) (value & 0x00FF);
} //这是将二进制转化成int类型的方法
public static int getIntAt(byte[] buffer,int offset) {
int value = 0;
//第一个value和上面的int类型转化成二进制对应起来,
//先将第一个取出来的左移24位与FF000000相与就是这八位,再相或就是原来的前八位
value |= buffer[offset + 0] << 24 & 0xFF000000;
value |= buffer[offset + 1] << 16 & 0x00FF0000;
value |= buffer[offset + 2] << 8 & 0x0000FF00;
value |= buffer[offset + 3] & 0x000000FF; return value;
} //这是将二进制转化成long类型的方法
public static long getLongAt(byte[] buffer,int offset) {
long value = 0;
//第一个value和上面的long类型转化成二进制对应起来,
//先将第一个取出来的左移64位与FF000000相与就是这八位,再相或就是原来的前八位
value |= buffer[offset + 0] << 56 & 0xFF00000000000000L;
value |= buffer[offset + 1] << 48 & 0x00FF000000000000L;
value |= buffer[offset + 2] << 40 & 0x0000FF0000000000L;
value |= buffer[offset + 3] << 32 & 0x000000FF00000000L;
value |= buffer[offset + 4] << 24 & 0x00000000FF000000L;
value |= buffer[offset + 5] << 16 & 0x0000000000FF0000L;
value |= buffer[offset + 6] << 8 & 0x0000000000000FF0L;
value |= buffer[offset + 7] & 0x00000000000000FFL; return value;
} }

三、说明:

位运算是比较凶悍的,计算精简。但是不容易理解,根据上述的注释,若有错误或者迷惑,欢迎指正。

关于Java实现的进制转化(位运算)的更多相关文章

  1. 【JavaScript】进制转换&位运算,了解一下?

    前言 在一般的代码中很少会接触到进制和位运算,但这不代表我们可以不去学习它.作为一位编程人员,这些都是基础知识.如果你没有学过这方面的知识,也不要慌,接下来的知识并不会很难.本文你将会学习到: 进制转 ...

  2. Python笔记_第一篇_面向过程_第一部分_3.进制、位运算、编码

    通过对内存这一个部分的讲解,对编程会有一个相对深入的认识.数据结构是整个内存的一个重要内容,那么关于数据结构这方面的问题还需要对进制.位运算.编码这三个方面再进行阐述一下.前面说将的数据结构是从逻辑上 ...

  3. C#的格式化(进制转换|位运算)

    1.首先做一下知识的普及C或c Currency 货币格式D或d Decimal 十进制格式E或e Exponent 指数格式F或f Fixed point (float)固定精度格式G或g Gene ...

  4. javascript中的类型转换(进制转换|位运算)

    1:parseInt(string) : 这个函数的功能是从string的开头开始解析,返回一个整数 parseInt("123hua"); //输出 123 parseInt(& ...

  5. 4.Python 进制和位运算

    .button, #logout { color: #333; background-color: #fff; border-color: #ccc; } span#login_widget > ...

  6. Codeforces Round #299 (Div. 2) B. Tavas and SaDDas【DFS/*进制思维/位运算/一个数为幸运数,当且仅当它的每一位要么是4,要么是7 ,求小于等于n的幸运数个数】

    B. Tavas and SaDDas time limit per test 1 second memory limit per test 256 megabytes input standard ...

  7. Java I/O : Java中的进制详解

    作者:李强强 上一篇,泥瓦匠基础地讲了下Java I/O : Bit Operation 位运算.这一讲,泥瓦匠带你走进Java中的进制详解. 一.引子 在Java世界里,99%的工作都是处理这高层. ...

  8. java中的进制转换方法

    java中进行二进制,八进制,十六进制,十进制间进行相互转换 关键字: java 进制转换 十进制转成十六进制: Integer.toHexString(int i) 十进制转成八进制 Integer ...

  9. HDU5050:Divided Land(大数的进制转化与GCD)

    题意:给定大数A和B,求gcd.所有数字都是二进制. 思路:先输入字符串,再转化为大数,然后用大数的gcd函数,最后转化为字符串输出. 利用字符串和大数转化的时候可以声明进制,就很舒服的完成了进制转化 ...

随机推荐

  1. 禁止单个IP或ip段访问

    //IP禁止判断接口,返回true则为找到 function checkIp($ip, $ipbanned) { $ipbannedFlag = false; if (!empty($ipbanned ...

  2. Spring Boot(十五):spring boot+jpa+thymeleaf增删改查示例

    Spring Boot(十五):spring boot+jpa+thymeleaf增删改查示例 一.快速上手 1,配置文件 (1)pom包配置 pom包里面添加jpa和thymeleaf的相关包引用 ...

  3. udp丢包 处理

    转自: 自己在做UDP传输时遇到的问题,接收端没设置缓存,结果总是丢包. 看到这篇文章设置了一下接收缓存就好 *;//设置为32K setsockopt(s,SOL_SOCKET,SO_RCVBUF, ...

  4. python简说(一)if,for等

    一.python简说 python可以用于自动化测试.web开发.数据分析.AI python.自动化运维,第三方模块最多的一个语言. 编译型语言 c.c++ 要运行,先要编译,编译成二进制的. 解释 ...

  5. vue2.0之element table的使用

    说明: 1.改变表头居中问题:    需要在el-table-column中添加  header-align="center" <el-table :data="t ...

  6. 实现 SPA 的三种方式

    什么是SPA? 单页Web应用(single page web application,SPA),就是只有一张Web页面的应用,是加载单个HTML 页面并在用户与应用程序交互时动态更新该页面的Web应 ...

  7. topcoder srm 703 div1 -3

    1.给出一个包含$n$个元素的数组$x$,构造出一个有向无环图满足从节点$i$出发可以访问到的节点数为$x_{i}$. 思路:按照$x$从小到大排序.然后从前向后处理,当前节点依次与前面已经处理的节点 ...

  8. upc组队赛1 不存在的泳池【GCD】

    不存在的泳池 题目描述 小w是云南中医学院的同学,有一天他看到了学校的百度百科介绍: 截止到2014年5月,云南中医学院图书馆纸本藏书74.8457万册,纸质期刊388种,馆藏线装古籍图书1.8万册, ...

  9. P2860 [USACO06JAN]冗余路径Redundant Paths tarjan

    题目链接 https://www.luogu.org/problemnew/show/P2860 思路 缩点,之后就成了个树一般的东西了 然后(叶子节点+1)/2就是答案,好像贪心的样子,lmc好像讲 ...

  10. C# 中2个问号的作用。C#的??代表是什么意思

    https://www.cnblogs.com/gggg/p/5867412.html 变量定义中含有一个问号,意思是这个数据类型是NullAble类型的.(NullAble意思是可以为空) 变量定义 ...