Java 进行BCC异或校验

            break;

        case 'd':

            result = 13;

            break;

        case 'e':

            result = 14;

            break;

        case 'f':

            result = 15;

            break;

        case 'A':

            result = 10;

            break;

        case 'B':

            result = 11;

            break;

        case 'C':

            result = 12;

            break;

        case 'D':

            result = 13;

            break;

        case 'E':

            result = 14;

            break;

        case 'F':

            result = 15;

            break;

        default:

            result = (short) Character.getNumericValue(x);

            break;

    }

    return result;

}



补充一个工具类



import android.graphics.Bitmap;

import android.graphics.BitmapFactory;

import java.io.FileInputStream;

import java.io.IOException;

import java.io.InputStream;

public class ByteUtil {

/**

 * 向串口发送数据转为字节数组

 */

public static byte[] hex2byte(String hex) {

    String digital = "0123456789ABCDEF";

    String hex1 = hex.replace(" ", "");

    char[] hex2char = hex1.toCharArray();

    byte[] bytes = new byte[hex1.length() / 2];

    byte temp;

    for (int p = 0; p < bytes.length; p++) {

        temp = (byte) (digital.indexOf(hex2char[2 * p]) * 16);

        temp += digital.indexOf(hex2char[2 * p + 1]);

        bytes[p] = (byte) (temp & 0xff);

    }

    return bytes;

}



/**

 * 接收到的字节数组转换16进制字符串

 */

public static String byteToStr(byte[] b, int size) {

    String ret = "";

    for (int i = 0; i < size; i++) {

        String hex = Integer.toHexString(b[i] & 0xFF);

        if (hex.length() == 1) {

            hex = '0' + hex;

        }

        ret += hex.toUpperCase();

    }

    return ret;

}



/**

 * 计算CRC16校验码

 * 逐个求和

 *

 * @param bytes 字节数组

 * @return {@link String} 校验码

 * @since 1.0

 */

public static String getCRC_16(byte[] bytes) {

    int CRC = 0x0000ffff;

    int POLYNOMIAL = 0x0000a001;

    int i, j;

    for (i = 0; i < bytes.length; i++) {

        CRC ^= ((int) bytes[i] & 0x000000ff);

        for (j = 0; j < 8; j++) {

            if ((CRC & 0x00000001) != 0) {

                CRC >>= 1;

                CRC ^= POLYNOMIAL;

            } else {

                CRC >>= 1;

            }

        }

    }

    if (Integer.toHexString(CRC).toUpperCase().length() == 2) {

        return byteToStr(bytes, bytes.length) + "00" + Integer.toHexString(CRC).toUpperCase();

    } else if (Integer.toHexString(CRC).toUpperCase().length() == 3) {

        return byteToStr(bytes, bytes.length) + "0" + Integer.toHexString(CRC).toUpperCase();

    }

    return byteToStr(bytes, bytes.length) + Integer.toHexString(CRC).toUpperCase();

}



/**

 * 指令校验和,并取出后两位字节

 * */

public static String getSum16(byte[] msg, int length) {

    long mSum = 0;

    byte[] mByte = new byte[length];



    /** 逐Byte添加位数和 */

    for (byte byteMsg : msg) {

        long mNum = ((long) byteMsg >= 0) ? (long) byteMsg : ((long) byteMsg + 256);

        mSum += mNum;

    } /** end of for (byte byteMsg : msg) */



    /** 位数和转化为Byte数组 */

    for (int liv_Count = 0; liv_Count < length; liv_Count++) {

        mByte[length - liv_Count - 1] = (byte) (mSum >> (liv_Count * 8) & 0xff);

    } /** end of for (int liv_Count = 0; liv_Count < length; liv_Count++) */

    return byteToStr(msg, length) + byteToStr(mByte, mByte.length).substring(byteToStr(mByte, mByte.length).length() - 4, byteToStr(mByte, mByte.length).length());

}

最后总结

搞定算法,面试字节再不怕,有需要文章中分享的这些二叉树、链表、字符串、栈和队列等等各大面试高频知识点及解析

最后再分享一份终极手撕架构的大礼包(学习笔记):分布式+微服务+开源框架+性能优化

image

(byteToStr(mByte, mByte.length).length() - 4, byteToStr(mByte, mByte.length).length());

}

最后总结

搞定算法,面试字节再不怕,有需要文章中分享的这些二叉树、链表、字符串、栈和队列等等各大面试高频知识点及解析

最后再分享一份终极手撕架构的大礼包(学习笔记):分布式+微服务+开源框架+性能优化

[外链图片转存中…(img-YU93PV8w-1714318893367)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值