首頁  >  文章  >  Java  >  Java中循環冗餘校驗的實作方式介紹

Java中循環冗餘校驗的實作方式介紹

黄舟
黄舟原創
2017-10-17 09:30:362021瀏覽

CRC校驗實用程式庫在資料儲存和資料通訊領域,為了確保資料的正確,就不得不採用檢錯的手段,以下這篇文章主要給大家介紹了關於Java中循環冗餘校驗( CRC32)實現的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

本文主要介紹給大家介紹了Java實作循環冗餘校驗(CRC32)的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

CRC32簡介

CRC校驗實用程式庫在資料儲存和資料通訊領域,為了確保資料的正確,就不得不採用檢錯的手段。在許多檢錯手段中,CRC是最著名的一種。 CRC的全名是循環冗餘校驗。

CRC32檢錯能力極強,開銷小,易於用編碼器及偵測電路實現。從其檢錯能力來看,它所不能發現的錯誤的幾率僅為0.0047%以下。從性能上和開銷上考慮,都遠優於奇偶校驗及算術和校驗等方式。因而,在資料儲存與資料通訊領域,CRC無所不在:著名的通訊協定X.25的FCS(幀檢錯序列)採用的是CRC-CCITT,ARJ、LHA等壓縮工具軟體採用的是CRC32,磁碟驅動器的讀寫採用了CRC16,通用的影像儲存格式GIF、TIFF等也都以CRC作為檢錯手段。

CRC實作


#
package com.jianggujin.codec;

import java.io.IOException;
import java.io.InputStream;
import java.util.zip.CRC32;

/**
 * CRC32
 * 
 * @author jianggujin
 *
 */
public class HQCRC32
{
  private static HQCRC32 crc32 = new HQCRC32();

  public static HQCRC32 getInstance()
  {
   return crc32;
  }

  private HQCRC32()
  {
  }

  private static final int STREAM_BUFFER_LENGTH = 1024;

  public long encrypt(byte[] data)
  {
   CRC32 crc32 = new CRC32();
   crc32.update(data);
   return crc32.getValue();
  }

  public long encrypt(InputStream data) throws IOException
  {
   final byte[] buffer = new byte[STREAM_BUFFER_LENGTH];
   int read = data.read(buffer, 0, STREAM_BUFFER_LENGTH);
   CRC32 crc32 = new CRC32();
   while (read > -1)
   {
     crc32.update(buffer, 0, read);
     read = data.read(buffer, 0, STREAM_BUFFER_LENGTH);
   }
   return crc32.getValue();
  }
}

測試程式碼:


import org.junit.Test;

import com.jianggujin.codec.HQCRC32;

public class CRC32Test
{
  HQCRC32 crc32 = HQCRC32.getInstance();

  @Test
  public void encode()
  {
   byte[] data = "jianggujin".getBytes();
   long result = crc32.encrypt(data);
   System.err.println(result);
  }
}

測試結果:

724585211

#總結

以上是Java中循環冗餘校驗的實作方式介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn