java 基本类型编解码
---------------------------------------------------
1.单字节编码就没有啥编解码问题了
2.多字节编辑码
1)big-endian 低地址存储高位
2)little-endian 低地址存储地位
3)针对不同的方式进行相应的解码就可以得到相应的数据,如果根据相反的方式及得不到相应的解码数据
3.数值的编辑码无非数值的左右移动得到相应的字节,放到相应的位置以及进行|操作
4.根据tcp/ip socket编程内容进行long类型编辑码
package com.pjf.echodemo;
import java.io.IOException;
import java.math.BigDecimal;
public class EncodeDecodeDemo {
public static void main(String[] args) throws Exception {
long data = 123456787654321l;
//以十六进行展示
System.out.println(Long.toHexString(data));
//以二进制展示
System.out.println(Long.toBinaryString(data));
//以十进制展示
System.out.println(printByteDecByLong(data, 1));
System.out.println(printByteDecByLong(data, 0));
System.out.println("==============高低位======================");
//将一个long转成高低位数组
byte[] bytes = longToByteArrayWithBigEndian(data);
//以高低位的方式将数据进行解析
System.out.println(readUnsignedLong(byteArrayToLongWithBigEndian(bytes)));
System.out.println("==============高低位======================");
System.out.println("==============低高位======================");
//将一个long转成地高位数组
byte[] littleBytes = longToByteArrayWithLittleEndian(data);
System.out.println(byteArrayToLongWithLittleEndian(littleBytes));
System.out.println("==============低高位======================");
// System.out.println(byteArrayToLongWithBigEndian(bytes));
// System.out.println(byteArrayToLongWithLittleEndian(bytes));
}
/***
* 将一个字节数组以10进制数据展示出来
*/
/***
*
* @param data
* 需要处理的数据
* @param type
* 0:小字节序发的方式打印,其他的方式已大字节序方式打印
* @return
*/
public static String printByteDecByLong(long data, int type) {
byte[] bytes = null;
if (type == 0) {
bytes = longToByteArrayWithLittleEndian(data);
} else {
bytes = longToByteArrayWithBigEndian(data);
}
StringBuilder sb = new StringBuilder();
for (byte b : bytes) {
sb.append(b & 0xff).append(" ");
}
return sb.toString();
}
/**
* 将long转成一个字节数组[字节序是大端] 高位在低地址位上
*/
public static byte[] longToByteArrayWithBigEndian(long a) {
return new byte[] { (byte) ((a >> 56) & 0xFF), (byte) ((a >> 48) & 0xFF), (byte) ((a >> 40) & 0xFF),
(byte) ((a >> 32) & 0xFF), (byte) ((a >> 24) & 0xFF), (byte) ((a >> 16) & 0xFF),
(byte) ((a >> 8) & 0xFF), (byte) (a & 0xFF) };
}
/**
* 将long转成一个字节数组[字节序是小端] 高位在低地址位上
*/
public static byte[] longToByteArrayWithLittleEndian(long a) {
return new byte[] { (byte) (a & 0xFF), (byte) ((a >> 8) & 0xFF), (byte) ((a >> 16) & 0xFF),
(byte) ((a >> 24) & 0xFF), (byte) ((a >> 32) & 0xFF), (byte) ((a >> 40) & 0xFF),
(byte) ((a >> 48) & 0xFF), (byte) ((a >> 56) & 0xFF) };
}
/**
*
* @param bytes
* 字节数
* @return
*/
public static long byteArrayToLongWithBigEndian(byte[] bytes) {
// return b[3] & 0xFF |
// (b[2] & 0xFF) << 8 |
// (b[1] & 0xFF) << 16 |
// b[0] & 0xFF) << 24;
return (bytes[0] & (long) 0xFF) << 56 | (bytes[1] & (long) 0xFF) << 48 | (bytes[2] & (long) 0xFF) << 40
| (bytes[3] & (long) 0xFF) << 32 | (bytes[4] & (long) 0xFF) << 24 | (bytes[5] & (long) 0xFF) << 16
| (bytes[6] & (long) 0xFF) << 8 | (bytes[7] & (long) 0xFF) << 0;
// long data = 0;
// int cnt = 8 - bytes.length;
// /**不够位进行补位*/
// int i=0;
// for ( i = 0; i < cnt; i++) {
//
// data = data | (0 & 0xFF) <<( 8 * (8-i));
// }
// /***
// * bytes已大端字节序进行转换
// */
// for(int j=0;j<=bytes.length-1;j++){
//
// data = data | ((bytes[j] & 0xFF) << (8 * (8-i-j-1)));
//
// }
// return data;
}
/***
*
* @param bytes 字节数据 little-endian
* @return
*/
public static long byteArrayToLongWithLittleEndian(byte[] bytes) {
return (bytes[0] & (long) 0xFF) << 0 | (bytes[1] & (long) 0xFF) << 8 | (bytes[2] & (long) 0xFF) << 16
| (bytes[3] & (long) 0xFF) << 24 | (bytes[4] & (long) 0xFF) << 32 | (bytes[5] & (long) 0xFF) << 40
| (bytes[6] & (long) 0xFF) << 48 | (bytes[7] & (long) 0xFF) << 56;
}
/**
*
* @param value 有符号的long数据
* @return 将有符号的long类型数据转成无符号的数据
* @throws IOException
*/
public static final BigDecimal readUnsignedLong(long value) throws IOException {
if (value >= 0)
return new BigDecimal(value);
long lowValue = value & 0x7fffffffffffffffL;
return BigDecimal.valueOf(lowValue).add(BigDecimal.valueOf(Long.MAX_VALUE)).add(BigDecimal.valueOf(1));
}
}
5.运行结果
6.java数值类型转换规则
如果最初的数值类型是有符号的,那么就执行符号扩展;如果是char类型,那么不管它要被转换成什么类型,都执行零扩展。还有另外一条规则也需要记住,如果目标类型的长度小于源类型的长度,则直接截取目标类型的长度。例如将int型转换成byte型,直接截取int型的右边8位。
以上仅仅作为学习记录!
- 大小: 31.3 KB
分享到:
相关推荐
本篇文章将深入探讨H264编解码的原理,并通过使用开源工具FFmpeg进行实践操作,提供源代码分析,以便于开发者更好地理解和应用。 H264编码的核心在于通过一系列复杂的算法,减少视频数据中的冗余信息,以达到在保持...
2.JNI接口:为了提高性能,通常会将关键的编解码操作封装在C/C++层,通过JNI(Java Native Interface)与Java层交互。这样可以利用硬件加速,提高解码速度。 3. 硬件解码支持:现代安卓设备通常具备硬件解码H.264的...
描述了基于SNMP协议的常用数据类型的种类及特性,按照ASN.1语法对管理信息库中悲观对象编码、解码的基本规则,用Java语言给予了实现。
在本项目中,开发者使用Java编写了一个小程序,实现了PNG图像的基本编解码功能。虽然这个小程序可能并不完美,存在一些算法不强大和已知的BUG,但它为理解PNG编解码原理和Java图形处理提供了基础示例。下面我们将...
开发者需要解析这些块来获取音频流的基本信息,如文件类型、数据长度、采样率、位深度和声道数等。 2. **数据读取**:解析完文件头后,可以跳过数据头并直接读取音频样本。音频样本通常是连续的整数或浮点数,代表...
通过学习这个源码项目,开发者不仅可以掌握H.264视频编解码的基本原理,还能了解如何在Android平台上实际应用这些知识,提升解决实际问题的能力。同时,这也是一个很好的实践机会,可以锻炼开发者对Java和Android...
总的来说,MessagePack编解码jar包为Java开发者提供了一个高效、轻量级的序列化工具,尤其适合在Netty等高性能网络框架中使用,以实现快速、低延迟的数据交换。通过`javassist`库的配合,还能实现更灵活的代码生成和...
在本文中,我们将探讨如何在Java环境中使用ZXing进行二维码的编解码操作。 首先,我们需要了解ZXing的基本功能。ZXing库支持以下主要功能: 1. **读取功能**:ZXing可以读取各种类型的条形码和二维码,包括但不...
它不仅支持基本的Redis命令,还对Redis的集群、哨兵(Sentinel)系统、管道(Pipeline)和自定义编解码器(Codec)有全面的支持,使得在Java环境中与Redis交互变得更加简单和高效。 二、线程安全与同步/异步API ...
本编解码控件专为开发人员设计,用于在应用程序中生成和读取QR码,从而简化集成过程。 一、QR码的基本原理 1. 结构:QR码由黑白相间的模块组成,分为数据区域、定位图案、校正图案、定时图案和静区等部分。其中,...
2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这款实例会对你有所帮助。 Calendar万年历 1个目标文件 EJB 模拟银行ATM流程及操作源代码 6个目标文件,EJB来模拟银行ATM机的流程及操作:获取系统属性...
集合Java源码#java-code-gen基于的Java源代码生成器集合 #子项目 ...bson-gen对生成的Bean编解码器的运行时依赖性,包括针对基本类型(如short,byte ...数组,枚举和通用列表类型)的额外编解码器。
总的来说,"java编的qq代码"是一个很好的学习资源,可以让初学者了解到Java在网络编程中的应用,理解基本的面向对象设计,以及意识到在实际项目中多线程的重要性。通过分析和改进这个项目,你可以逐步提高你的编程...
例如,要查找支持特定MIME类型的编解码器,我们可以遍历`MediaCodecInfo`数组,对每个编解码器检查其是否支持指定的MIME类型。这通常通过调用`isEncoder()`和`getSupportedTypes()`方法来实现。`isEncoder()`用于...
通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥,通常应对私钥加密后再保存、如何从...
通过本源码可以了解到Java如何产生单钥加密的密钥(myKey)、产生双钥的密钥对(keyPair)、如何保存公钥的字节数组、保存私钥到文件privateKey.dat、如何用Java对象序列化保存私钥,通常应对私钥加密后再保存、如何从...
视频聊天功能涉及音视频编解码技术,这通常需要第三方库,如FFmpeg。Java可以通过JNI(Java Native Interface)调用C/C++编写的库来处理音视频数据。此外,Java的`javax.media`包也提供了一些基本的多媒体处理能力...
* Netty 的编解码和传输机制 * Netty 的应用场景和优缺点 缓存 缓存是软件系统中的一种优化技术,用于提高系统的性能和响应速度。缓存知识点包括: * 缓存的基本概念和类型 * 缓存的实现和优化 * 缓存的应用场景...
例如,Java与C/C++之间的数据转换需谨慎处理,避免内存泄漏或数据类型不匹配的问题。同时,如果多个线程并发调用JNI接口,需要确保解码操作的线程安全。 总之,通过OSS_tool解析OER编码,结合JNI技术,可以在Java...
这个工具箱提供了丰富的功能,包括编解码、编码转换、加解密、哈希计算、消息认证代码(MAC)、数字签名、大数运算、数据压缩以及二维码生成,同时也支持插件扩展,非常适合CTF(Capture The Flag)网络安全竞赛和...