首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

一段C语言的CRC验证代码,如何样用Java的代码来写?请各位哥哥相助,100分送

2012-02-24 
一段C语言的CRC验证代码,怎么样用Java的代码来写?请各位哥哥相助,100分送一段C语言的CRC验证代码,怎么样用

一段C语言的CRC验证代码,怎么样用Java的代码来写?请各位哥哥相助,100分送
一段C语言的CRC验证代码,怎么样用Java的代码来写?请各位哥哥相助,100分送。
小弟俺有很多可用分,不够开帖再送~!!


#include   "kernel.h "
#include   "GNtsLib.h "

static   const   unsigned   short   s_us_CrcTab16[256]   =   {
        0x0000,     0x1021,     0x2042,     0x3063,     0x4084,     0x50a5,     0x60c6,     0x70e7,
        0x8108,     0x9129,     0xa14a,     0xb16b,     0xc18c,     0xd1ad,     0xe1ce,     0xf1ef,
        0x1231,     0x0210,     0x3273,     0x2252,     0x52b5,     0x4294,     0x72f7,     0x62d6,
        0x9339,     0x8318,     0xb37b,     0xa35a,     0xd3bd,     0xc39c,     0xf3ff,     0xe3de,
        0x2462,     0x3443,     0x0420,     0x1401,     0x64e6,     0x74c7,     0x44a4,     0x5485,
        0xa56a,     0xb54b,     0x8528,     0x9509,     0xe5ee,     0xf5cf,     0xc5ac,     0xd58d,
        0x3653,     0x2672,     0x1611,     0x0630,     0x76d7,     0x66f6,     0x5695,     0x46b4,
        0xb75b,     0xa77a,     0x9719,     0x8738,     0xf7df,     0xe7fe,     0xd79d,     0xc7bc,
        0x48c4,     0x58e5,     0x6886,     0x78a7,     0x0840,     0x1861,     0x2802,     0x3823,
        0xc9cc,     0xd9ed,     0xe98e,     0xf9af,     0x8948,     0x9969,     0xa90a,     0xb92b,
        0x5af5,     0x4ad4,     0x7ab7,     0x6a96,     0x1a71,     0x0a50,     0x3a33,     0x2a12,
        0xdbfd,     0xcbdc,     0xfbbf,     0xeb9e,     0x9b79,     0x8b58,     0xbb3b,     0xab1a,
        0x6ca6,     0x7c87,     0x4ce4,     0x5cc5,     0x2c22,     0x3c03,     0x0c60,     0x1c41,
        0xedae,     0xfd8f,     0xcdec,     0xddcd,     0xad2a,     0xbd0b,     0x8d68,     0x9d49,
        0x7e97,     0x6eb6,     0x5ed5,     0x4ef4,     0x3e13,     0x2e32,     0x1e51,     0x0e70,
        0xff9f,     0xefbe,     0xdfdd,     0xcffc,     0xbf1b,     0xaf3a,     0x9f59,     0x8f78,
        0x9188,     0x81a9,     0xb1ca,     0xa1eb,     0xd10c,     0xc12d,     0xf14e,     0xe16f,
        0x1080,     0x00a1,     0x30c2,     0x20e3,     0x5004,     0x4025,     0x7046,     0x6067,
        0x83b9,     0x9398,     0xa3fb,     0xb3da,     0xc33d,     0xd31c,     0xe37f,     0xf35e,


        0x02b1,     0x1290,     0x22f3,     0x32d2,     0x4235,     0x5214,     0x6277,     0x7256,
        0xb5ea,     0xa5cb,     0x95a8,     0x8589,     0xf56e,     0xe54f,     0xd52c,     0xc50d,
        0x34e2,     0x24c3,     0x14a0,     0x0481,     0x7466,     0x6447,     0x5424,     0x4405,
        0xa7db,     0xb7fa,     0x8799,     0x97b8,     0xe75f,     0xf77e,     0xc71d,     0xd73c,
        0x26d3,     0x36f2,     0x0691,     0x16b0,     0x6657,     0x7676,     0x4615,     0x5634,
        0xd94c,     0xc96d,     0xf90e,     0xe92f,     0x99c8,     0x89e9,     0xb98a,     0xa9ab,
        0x5844,     0x4865,     0x7806,     0x6827,     0x18c0,     0x08e1,     0x3882,     0x28a3,
        0xcb7d,     0xdb5c,     0xeb3f,     0xfb1e,     0x8bf9,     0x9bd8,     0xabbb,     0xbb9a,
        0x4a75,     0x5a54,     0x6a37,     0x7a16,     0x0af1,     0x1ad0,     0x2ab3,     0x3a92,
        0xfd2e,     0xed0f,     0xdd6c,     0xcd4d,     0xbdaa,     0xad8b,     0x9de8,     0x8dc9,
        0x7c26,     0x6c07,     0x5c64,     0x4c45,     0x3ca2,     0x2c83,     0x1ce0,     0x0cc1,
        0xef1f,     0xff3e,     0xcf5d,     0xdf7c,     0xaf9b,     0xbfba,     0x8fd9,     0x9ff8,
        0x6e17,     0x7e36,     0x4e55,     0x5e74,     0x2e93,     0x3eb2,     0x0ed1,     0x1ef0
};

H     Crc_GetCRC16(   UB   *pubData,   H   hSize,   H   hCurrentCRC   )
{
        HhCount;

        for   (   hCount   =   0   ;   hCount   <   hSize   ;   hCount++   )   {
                hCurrentCRC   =   (   s_us_CrcTab16[((hCurrentCRC   > >   8)   &   0x00FF)]   ^   (hCurrentCRC   < <   8)   ^   *(pubData   +   hCount));
        }

        return   (   hCurrentCRC   );
}




[解决办法]
去java版求
[解决办法]
虽然LS说的很无情,但是说的是事实。

如果在这里问,这里即使有人帮你做也是从C++的观点去做。

而你这个问题`,最好找些能从JAVA的立场重新从头考虑你的问题的人去做。
[解决办法]
呃,不会java
------解决方案--------------------


java不熟,你可以到java版快去问
[解决办法]
还有你那些数据类
H
UB

到底是什么
[解决办法]
两套都精通的还是比较少,这类代码应该有现成的,找找吧
[解决办法]
不會。

轉java版塊吧。


[解决办法]
java.util.zip
类 CRC32
[解决办法]
http://blog.csdn.net/ainibaobao/archive/2006/04/24/675753.aspx
[解决办法]

[解决办法]
CRC16, 直接找 java 的就是了:

java语言实现CRC16算法
关键字: Java CRC16
由于工作需要,完成上下微机的com口的通讯,所以要用JAVA语言实现CRC16算法,完成通讯后字节流的校验功能。 而在编写数据传输程序时,数据容错是一个非常重要的问题。循环冗余位校验(CycliclRedundncyCheck英文简称CRC)是目前运用非常广泛的一种数据容错方法,在数据传输,数据压缩等领域运用极其广泛。

CRC算法实现有2种方法,一、查表法,二、直接计算,查表法的计算速度相对来说比较快,本人介绍的方法是直接计算法,用了2种方法实现,都是面向对象进行算法的封装。

一、

package com.wms.serial;

/**
* @author linduo
* @version 2006/08/25
*/
public class CRC16{
public int value;

public CRC16()
{
value = 0;
}

/** update CRC with byte b */
public void update(byte aByte)
{
int a, b;

a = (int) aByte;
for (int count = 7; count > =0; count--) {
a = a < < 1;
b = (a > > > 8) & 1;
if ((value & 0x8000) != 0) {
value = ((value < < 1) + b) ^ 0x1021;
} else {
value = (value < < 1) + b;
}
}
value = value & 0xffff;
return;
}

/** reset CRC value to 0 */
public void reset()
{
value = 0;
}

public int getValue()
{
return value;
}

public static void main(String[] args) {
CRC16 crc16 = new CRC16();
byte[] b = new byte[]{
//(byte) 0xF0,(byte)0xF0,(byte)0xF0,(byte)0x72
(byte) 0x2C,(byte)0x00,(byte)0xFF,(byte)0xFE
,(byte) 0xFE,(byte)0x04,(byte)0x00,(byte)0x00
,(byte) 0x00,(byte)0x00
};
for (int k = 0; k < b.length; k++)
{
crc16.update(b[k]);
}
System.out.println(Integer.toHexString(crc16.getValue()));
System.out.println(Integer.toHexString(b.length));
}
}

二、
package com.wms.serial;

public class CRC162 {
public static final void main(String[] args){
CRC162 crc16 = new CRC162();
byte[] b = new byte[]{
//(byte) 0xF0,(byte)0xF0,(byte)0xF0,(byte)0x72
(byte) 0x2C,(byte)0x00,(byte)0xFF,(byte)0xFE
,(byte) 0xFE,(byte)0x04,(byte)0x00,(byte)0x00
,(byte) 0x00,(byte)0x00
};
System.out.println(Integer.toHexString(crc16.encode(b)));
//再把这个2f49替换成b数组的最后两个字节的数组,生成一个新的数组b2
byte[] b2 = new byte[]{
//(byte) 0xF0,(byte)0xF0,(byte)0xF0,(byte)0x72
(byte) 0x2C,(byte)0x00,(byte)0xFF,(byte)0xFE
,(byte) 0xFE,(byte)0x04,(byte)0x00,(byte)0x00
,(byte) 0x2f,(byte)0x49
};
System.out.println(Integer.toHexString(crc16.encode(b2))); //算出来是 0

//你可以自已构造一些byte进行加解密试试
}

public short encode(byte[] b){
short CRC_x = 0;
int pp = 65536; // 1 < <16;
int pp2 = 69665; // (1 < <16) + (1 < <12) + (1 < <5) + 1
for(int i=0;i <b.length;i++){
for(int j=0;j <8;j++){
CRC_x = (short)((CRC_x < <1) + (((b[i] < <j)&0x80)> > 7));


if((CRC_x/pp) == 1){
CRC_x=(short)(CRC_x^pp2);
}
}
}
return CRC_x;
}
}

http://linduo168.javaeye.com/blog/27143
[解决办法]
/*************************************************************************
* Compilation: javac CRC16.java
* Execution: java CRC16 s
*
* Reads in a string s as a command-line argument, and prints out
* its 16-bit Cyclic Redundancy Check (CRC16). Uses a lookup table.
*
* Reference: http://www.gelato.unsw.edu.au/lxr/source/lib/crc16.c
*
* % java CRC16 123456789
* CRC16 = bb3d
*
* Uses irreducible polynomial: 1 + x^2 + x^15 + x^16
*
*
*************************************************************************/

public class CRC16 {

public static void main(String[] args) {

int[] table = {
0x0000, 0xC0C1, 0xC181, 0x0140, 0xC301, 0x03C0, 0x0280, 0xC241,
0xC601, 0x06C0, 0x0780, 0xC741, 0x0500, 0xC5C1, 0xC481, 0x0440,
0xCC01, 0x0CC0, 0x0D80, 0xCD41, 0x0F00, 0xCFC1, 0xCE81, 0x0E40,
0x0A00, 0xCAC1, 0xCB81, 0x0B40, 0xC901, 0x09C0, 0x0880, 0xC841,
0xD801, 0x18C0, 0x1980, 0xD941, 0x1B00, 0xDBC1, 0xDA81, 0x1A40,
0x1E00, 0xDEC1, 0xDF81, 0x1F40, 0xDD01, 0x1DC0, 0x1C80, 0xDC41,
0x1400, 0xD4C1, 0xD581, 0x1540, 0xD701, 0x17C0, 0x1680, 0xD641,
0xD201, 0x12C0, 0x1380, 0xD341, 0x1100, 0xD1C1, 0xD081, 0x1040,
0xF001, 0x30C0, 0x3180, 0xF141, 0x3300, 0xF3C1, 0xF281, 0x3240,
0x3600, 0xF6C1, 0xF781, 0x3740, 0xF501, 0x35C0, 0x3480, 0xF441,
0x3C00, 0xFCC1, 0xFD81, 0x3D40, 0xFF01, 0x3FC0, 0x3E80, 0xFE41,
0xFA01, 0x3AC0, 0x3B80, 0xFB41, 0x3900, 0xF9C1, 0xF881, 0x3840,
0x2800, 0xE8C1, 0xE981, 0x2940, 0xEB01, 0x2BC0, 0x2A80, 0xEA41,
0xEE01, 0x2EC0, 0x2F80, 0xEF41, 0x2D00, 0xEDC1, 0xEC81, 0x2C40,
0xE401, 0x24C0, 0x2580, 0xE541, 0x2700, 0xE7C1, 0xE681, 0x2640,
0x2200, 0xE2C1, 0xE381, 0x2340, 0xE101, 0x21C0, 0x2080, 0xE041,
0xA001, 0x60C0, 0x6180, 0xA141, 0x6300, 0xA3C1, 0xA281, 0x6240,
0x6600, 0xA6C1, 0xA781, 0x6740, 0xA501, 0x65C0, 0x6480, 0xA441,
0x6C00, 0xACC1, 0xAD81, 0x6D40, 0xAF01, 0x6FC0, 0x6E80, 0xAE41,
0xAA01, 0x6AC0, 0x6B80, 0xAB41, 0x6900, 0xA9C1, 0xA881, 0x6840,
0x7800, 0xB8C1, 0xB981, 0x7940, 0xBB01, 0x7BC0, 0x7A80, 0xBA41,
0xBE01, 0x7EC0, 0x7F80, 0xBF41, 0x7D00, 0xBDC1, 0xBC81, 0x7C40,
0xB401, 0x74C0, 0x7580, 0xB541, 0x7700, 0xB7C1, 0xB681, 0x7640,
0x7200, 0xB2C1, 0xB381, 0x7340, 0xB101, 0x71C0, 0x7080, 0xB041,
0x5000, 0x90C1, 0x9181, 0x5140, 0x9301, 0x53C0, 0x5280, 0x9241,
0x9601, 0x56C0, 0x5780, 0x9741, 0x5500, 0x95C1, 0x9481, 0x5440,
0x9C01, 0x5CC0, 0x5D80, 0x9D41, 0x5F00, 0x9FC1, 0x9E81, 0x5E40,
0x5A00, 0x9AC1, 0x9B81, 0x5B40, 0x9901, 0x59C0, 0x5880, 0x9841,
0x8801, 0x48C0, 0x4980, 0x8941, 0x4B00, 0x8BC1, 0x8A81, 0x4A40,
0x4E00, 0x8EC1, 0x8F81, 0x4F40, 0x8D01, 0x4DC0, 0x4C80, 0x8C41,
0x4400, 0x84C1, 0x8581, 0x4540, 0x8701, 0x47C0, 0x4680, 0x8641,
0x8201, 0x42C0, 0x4380, 0x8341, 0x4100, 0x81C1, 0x8081, 0x4040,
};


byte[] bytes = args[0].getBytes();
int crc = 0x0000;
for (byte b : bytes) {
crc = (crc > > > 8) ^ table[(crc ^ b) & 0xff];
}

System.out.println( "CRC16 = " + Integer.toHexString(crc));

}



}
[解决办法]
我对LS的佩服如涛涛江水。。。

热点排行