java float/double转化byte[] 与C++端接收

我们先来看下float和double在java端是如何转化为byte[], 透过网络传输的.

目前我仅考虑了两种方式:

①分别使用float和double提供的java api实现float和double到byte[]的转换

②将float和double分别转化为String,然后透过String的java api实现byte转换


下面分别说下这两种情况:

针对第一种

透过java api可以分别将float转为Integer, double转为Long, 而integer和Long在转化为byte[]就比较简单. 这样做,能够确保float和double所占内存空间不变, 分别是4 bytes和8 bytes, 但是可能会存在精度问题.

针对第二种

分别将float 和 double转化为String, 这样能够确保在C++端接收到的数据与java端完全相同, 但是使用String, 内存占用会变大.


我们在这里着重描述第一种情况:使用float和double提供的java api实现float和double到byte[]的转换.

使用Float.floatToIntBits()将 float 转化为Integer, 然后将Integer转为byte[], 当C++端在接收到byte[]时要如何解析呢?毕竟我们不了解Float.floatToIntBits是如何实现的.

不用担心,java api提供的Float.intBitsToFloat()中描述很清楚的告诉我们, 应该使用何种算法在C++端将这个byte[]正确转化为float(黑体部分引自JDK API 1.6.0).

sem 为可以通过以下参数进行计算的三个值;

int s = ((bits >> 31) == 0) ? 1 : -1;
int e = ((bits >> 23) & 0xff);
int m = (e == 0) ?
                (bits & 0x7fffff) << 1 :
                (bits & 0x7fffff) | 0x800000;
 
那么浮点结果等于算术表达式 s·m·2e-150 的值。  

注意, 此处e-150的含义如下:

float移位以23为基准(22-0表示尾数(fraction)), 以23分界,指数大于23则左移,否则右移, 由于指数用偏移表示,所以23+127=150.


我们可以用这种方式在C++端将float正确解析出来, 看到这个算法, 相信已经有人发现,这个实际上应该就是float在内存中的存储方式, 这样的话, 我们会有一个更加简单的方式, 来实现C++端解析float, 即:

union toFloat

{

byte bytePtr[4];

float floatValue;

};

toFloat toFloatValue;

int byteArrayLen = sizeof(toFloatValue.bytePtr);

memcpy(toFloatValue.bytePtr, byteValue, byteArrayLen);


toFloatValue.floatValue就是我们需要解析的java端的float值.


Double在传输和解析过程参考float即可.


如果有哪里说法不准确或者错误,欢迎大家指正, 希望对大家有帮助.

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java语言的语法机制与C和C++在某些方面有相似之处,但也存在一些明显的不同,主要表现在以下几个方面: 1. 数据类型:Java语言中的数据类型是严格定义的,与C/C++不同,Java没有指针类型。Java中的基本数据类型包括byte、short、intlongfloatdouble、char、boolean等,而C/C++中还有unsigned、signed等数据类型。 2. 内存管理:Java语言中的内存管理由垃圾回收器负责,程序员无需手动管理内存,而C/C++需要程序员手动进行内存分配和释放。 3. 异常处理:Java语言中有异常处理机制,可以让程序员在代码中捕获和处理异常,而C/C++中没有异常处理机制,通常使用返回值或全局变量表示函数的执行状态。 4. 类和对象:Java是一种面向对象的语言,类和对象是Java程序的基本组成部分,而C/C++是一种面向过程的语言,类和对象不是必须的。 5. 继承和多态:Java支持类的继承和多态,可以方便地实现代码的复用和扩展,而C++也支持类的继承和多态,但C语言不支持。 6. 接口:Java中有接口的概念,可以定义一组方法的规范,实现类必须实现这些方法,而C/C++没有接口的概念。 7. 包(Package):Java中有包的概念,可以将类组织成逻辑上的模块,方便代码的管理和重用,而C/C++没有包的概念。 总之,Java语言的语法机制与C/C++有些相似之处,但在数据类型、内存管理、异常处理、类和对象、继承和多态、接口、包等方面都有一些明显的不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值