[Java工具] 关于byte和int的转换
需求
单片机通过Socket发送过来类似 { 0xff,0x0c ,0x80...}的byte数组,根据协议分为unsigned char 和signed char两种类型。需要将int数据转为两个byte发送给单片机,或将单片机发来的2个byte转化为int。
工具程序
/** * 将两个byte数据转化为有符号int * @param high : 高八位 * @param low : 低八位 * @return */ public static int twoByteToSignedInt(byte high,byte low){ return (high << 8) | low; } /** * 将两个byte数据转化为无符号int * @param high : 高八位 * @param low : 低八位 * @return */ public static int twoByteToUnsignedInt(byte high,byte low){ return ((high << 8) & 0xffff) | (low & 0x00ff); } /** * 将int转换为两个byte * @param numInt : 实际只取其中的低16位二进制数 * @return 长度为2的byte数组 ,byte[0]为高8位,byte[1]为低八位 */ public static byte[] intToTwoByte(int numInt){ byte[] rest = new byte[2]; if(numInt < -32768 || numInt > 32767){ return null; } rest[0] = (byte)(numInt >> 8);//高8位 rest[1] = (byte)(numInt & 0x00ff);//低8位 return rest; }
解释
- 单片机发送过来的数据有 unsigned char 和 signed char 之分;而 Java 中的 byte(8位)、int(32位) 都是有符号的。
- 计算机里的数字,不管正负,其底层都是以补码形式存在的!!
- Java 的二进制采用补码形式。比如 Java 里的 Integer.toBinaryString(int) 函数,如果传入负数,则只会输出其补码形式,传入正数则输出原码二进制数(正数补码=原码)。
signed char 转为 Java 的有符号 int
参见函数 twoByteToSignedInt(byte high,byte low) 。由于在单片机中signed char也是以补码形式存在,所以直接用位操作将两个byte拼接为一个int即可。unsigned char 转为 Java 的无符号 int
参见函数 twoByteToUnsignedInt(byte high,byte low) 。那为什么要按位与0xffff呢?因为byte->int会发生符号扩展,这在转为有符号int时没有影响,但在转为无符号int时,符号扩展会造成数值出现误差。
具体来说,比如对于一个byte,如果不进行& 0xff,那么当一个byte会转换成int时,由于int是32位,而byte只有8位这时会进行f符号扩展,例如补码11111111的十进制数为-1,转换为int时变为1111 1111 1111 1111 1111 1111 1111 1111(补码)即0xffffffff但是这个数是不对的,这种补位就会造成误差。和0xff相与后,高24比特就会被清0了,结果就对了。int 转为 unsigned/signed char
参见intToTwoByte(int numInt)。
直接取int里的低16位即可。因为无论正负,在单片机里都是以补码形式存在,不需要额外转换。
参考
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
多线程之并发基础(三)
线程是轻量级的进程,进程可以说是线程的容器。线程是程序执行的最小单位。使用多线程而不是使用多进程进行并发程序的设计,因为线程的切换和调度成本远远小于进程。 与文无关 本文知识点目录: 线程的状态 线程的常见操作 Daemon线程 线程优先级 wait与notify 线程的状态 在Java程序中,线程有如下状态 NEW(新建): 新的线程刚刚创建,还没有启动。 Runnable(就绪):线程已经调用了start方法,正在被JVM执行的时候,也有可能正在等待某个操作系统的资源。 Blocked(阻塞):有其它线程占着锁不释放,当前线程阻塞与锁 Waiting(等待):表示当前线程需要等待其它线程做出一些特定动作(通知或中断),当调用以下方法时会进入此状态。 Object.wait()没有时间参数 Thread.join()没有超时参数 LockSupport.park方法 Timed Waiting(等待并计时):指定时间waiting,一边等,一边计时,一般调用如下方法可以j进入此状态。 Thread.sleep Object.wait()带有参数 Thread.join ()带有超时参...
- 下一篇
www.xttblog.com尚硅谷Java视频教程_SpringBoot视频教程
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xmt1139057136/article/details/79831708 SpringBoot是企业级开发的整体整合解决方案,特别用于快速构建微服务应用,旨在用最简单的方式让开发人员适应各种开发场景; 本视频着重介绍SpringBoot的使用和内部原理;内容包含微服务概念、配置文件、日志框架的使用、web开发、Thymeleaf模板引擎、Docker容器技术、MyBatis、Spring Data JPA、自定义starter等; 学习本套视频最基本需要掌握Spring、SpringMVC、Maven;最好配合《Spring注解版》一起学习效果更好。 00、尚硅谷_SpringBoot_源码、课件 01、尚硅谷_SpringBoot_入门-课程简介 02、尚硅谷_SpringBoot_入门-Spring Boot简介 03、尚硅谷_SpringBoot_入门-微服务简介 04、尚硅谷_SpringBoot_入门-环境准备 05、尚硅谷_SpringBoot_入门-springboot-...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7设置SWAP分区,小内存服务器的救世主
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- SpringBoot2全家桶,快速入门学习开发网站教程
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS8编译安装MySQL8.0.19