`
sunzhenyuan
  • 浏览: 39643 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

CRC16算法Java实现

阅读更多

模仿C++代码改写的Java实现

 

public class CRC16 {
    private short[] crcTable = new short[256];
    private int gPloy = 0x1021; // 生成多项式

    public CRC16() {
        computeCrcTable();
    }

    private short getCrcOfByte(int aByte) {
        int value = aByte << 8;

        for (int count = 7; count >= 0; count--) {
            if ((value & 0x8000) != 0) { // 高第16位为1,可以按位异或
                value = (value << 1) ^ gPloy;
            } else {
                value = value << 1; // 首位为0,左移
            }

        }
        value = value & 0xFFFF; // 取低16位的值
        return (short)value;
    }

    /*
     * 生成0 - 255对应的CRC16校验码
     */
    private void computeCrcTable() {
        for (int i = 0; i < 256; i++) {
            crcTable[i] = getCrcOfByte(i);
        }
    }

    public short getCrc(byte[] data) {
        int crc = 0;
        int length = data.length;
        for (int i = 0; i < length; i++) {
            crc = ((crc & 0xFF) << 8) ^ crcTable[(((crc & 0xFF00) >> 8) ^ data[i]) & 0xFF];
        }
        crc = crc & 0xFFFF;
        return (short)crc;
    }
}

 

public final class CodecUtil {
    static CRC16 crc16 = new CRC16();

    private CodecUtil() {
    }

    public static byte[] short2bytes(short s) {
        byte[] bytes = new byte[2];
        for (int i = 1; i >= 0; i--) {
            bytes[i] = (byte)(s % 256);
            s >>= 8;
        }
        return bytes;
    }

    public static short bytes2short(byte[] bytes) {
        short s = (short)(bytes[1] & 0xFF);
        s |= (bytes[0] << 8) & 0xFF00;
        return s;
    }

    /*
     * 获取crc校验的byte形式
     */
    public static byte[] crc16Bytes(byte[] data) {
        return short2bytes(crc16Short(data));
    }

    /*
     * 获取crc校验的short形式
     */
    public static short crc16Short(byte[] data) {
        return crc16.getCrc(data);
    }

    public static void main(String[] args) {
        byte[] test = new byte[] {0, 1, 2, 3, 4};
        byte[] crc = crc16Bytes(test);

        byte[] testc = new byte[test.length + 2];
        for (int i = 0; i < test.length; i++) {
            testc[i] = test[i];
        }
        testc[test.length] = crc[0];
        testc[test.length + 1] = crc[1];

        System.out.println(crc16Short(testc));
    }
}

分享到:
评论
3 楼 379548695 2009-11-18  
能帮我把这个改成java的吗

#include<string.h>  /* CRC-8 按位计算实现  */

 unsigned
  int cal_crc(unsigned char *ptr, unsigned char len) {
     unsigned char i;
     unsigned char crc=0;
     while(len--!=0)
        {
          for(i=0x80; i!=0; i/=2)
            {
                  if((crc&0x80)!=0)
                        {crc*=2; crc^=0x1f;}   /* 余式CRC乘以2再求CRC  */
                    else crc*=2;
                 if((*ptr&i)!=0) crc^=0x1f;                /* 再加上本位的CRC */
             }
        ptr++;
        }
  return(crc);
}

int  main()
{
      char *a="410400110012";
      printf("%d\n",cal_crc(a,strlen(a))) ;
      getch();
}
2 楼 sunzhenyuan 2009-02-03  
sdh5724 写道

好像现在JAVA API已经有了吧。 :)

呵呵,API里的那个不是完整的实现。
1 楼 sdh5724 2009-01-17  
好像现在JAVA API已经有了吧。 :)

相关推荐

    Java版CRC16校验算法

    CRC16校验算法及十六进制和十六进制字符串转换

    java 实现的CRC32算法

    用java 编写实现的CRC32算法,很详细

    Java 实现CRC码算法(含实现原理和步骤)

    尽管Java标准库已经提供了CRC32的实现类 `java.util.zip.CRC32`,但从教学的角度出发,手动实现一个简化的CRC算法可以更好地帮助理解CRC的工作原理。下面给出一个简化的CRC-4算法的Java实现示例: ```java public ...

    CRC算法 (Java版)

    在Java中实现CRC算法,通常涉及以下几个关键步骤: 1. **选择CRC多项式**:CRC有不同的版本,如CRC-8、CRC-16、CRC-32和CRC-64,每种对应不同的预定义多项式。例如,CRC-32使用的多项式是0x4C11DB7,CRC-16可能是0...

    CRC16,CRC-CCITT JAVA算法

    CRC16,CRC-CCITT JAVA算法

    crc16校验java实现

    从数据头到校验码前的CRC16-CCITT的校验值,遵循大端排序方式的规定。CRC16-CCITT码生成多项式为x16+x12+x5+1,简记式1021。

    java实现 crc16校验工具和代码

    1. 支持多种CRC算法,如CRC16-CCITT、CRC16-KERMIT等。 2. 提供API供其他程序调用,方便集成到项目中。 3. 可能包含了性能优化,比如使用查找表来加速CRC计算。 总的来说,理解并掌握CRC16校验机制对于确保数据的...

    CRC16 MODBUS校验算法实现

    CRC16 MODBUS校验算法实现涉及到对数据进行特定的计算,以产生一个16位的校验码,这个校验码可以用于检查数据是否在传输过程中发生了错误。 1. CRC16原理 CRC16的核心在于一个称为生成多项式(Generator Polynomial...

    JAVA下两种方法实现CRC算法

    JAVA下使用两种方法(计算法、查表法)实现CRC(XMODEM)算法,以及验证代码

    crc8源码JAVA实现

    crc8源码JAVA查表法实现,已测试通过。

    crc16_java_CRC16_

    在Java编程中,实现CRC16算法可以帮助我们确保数据的完整性和一致性。本文将详细讲解CRC16的基本原理、Java实现方式以及CRC16.java文件中的关键代码。 ### CRC16基本原理 CRC16的核心是通过一个预定义的多项式...

    CRC16校验java版

    在Java编程语言中实现CRC16校验可以帮助开发者创建可靠的数据传输系统,特别是对于Modbus协议等工业通信标准而言,CRC16是不可或缺的一部分。 CRC,全称Cyclic Redundancy Check(循环冗余校验),是一种利用多项式...

    基于MODBUS协议的CRC16校验算法-PB

    在PB语言中,实现基于MODBUS协议的CRC16校验算法可以使用函数fx_modbus_crc16,该函数可以对输入的字符串进行CRC16校验,并返回16进制字符串的CRC16校验值。 函数fx_modbus_crc16的实现过程可以分为以下几个步骤: ...

    java编写的两个modbus CRC16实现

    标题中的“java编写的两个modbus CRC16实现”指的是使用Java编程语言实现的两种Modbus协议中的CRC16校验方法。CRC(Cyclic Redundancy Check,循环冗余校验)是一种广泛用于数据传输错误检测的校验码技术,而Modbus...

    CRC16循环冗余算法

    CRC16循环冗余算法,高位在前和低位在后都有; 对特定字符串进行转换成16进制字符串,然后将字符串进行CRC16校验,得到校验码. 次工具类已经经过本人亲自验证,完全符合标准,目前项目中用到的就是这个工具类.

    java版_ModBus_CRC16校验

    java ModBus CRC 16 校验_(亲测成功) 还有一个在线版本的 https://www.lammertbies.nl/comm/info/crc-calculation.html

    这是一个符合modbus协议的CRC16校验算法的java代码的实现.zip

    到处运行(Write Once, Run Anywhere)”,这意味着开发者可以使用Java编写应用程序,并在支持Java的任何平台上无需重新编译即可运行,这得益于其独特的跨平台性,通过Java虚拟机(JVM)实现不同操作系统上的兼容。...

    CRC-16_crc16校验stm32_

    CRC-16是CRC算法的一种,它生成一个16位的校验码,能有效地检测出数据中的错误。 STM32是意法半导体(STMicroelectronics)推出的基于ARM Cortex-M内核的微控制器系列,具有高性能、低功耗、丰富的外设等特点。在...

    CRC冗余校验java实现代码

    CRC冗余校验,使用java实现,共同学习!!

Global site tag (gtag.js) - Google Analytics