⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 crc16.java

📁 这是一个以JAVA编写的程序,本人还没有试过,是一个简单的温度控制系统
💻 JAVA
字号:
/*--------------------------------------------------------------------------- * Copyright (C) 1999,2000 Dallas Semiconductor Corporation, All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY,  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL DALLAS SEMICONDUCTOR BE LIABLE FOR ANY CLAIM, DAMAGES * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. * * Except as contained in this notice, the name of Dallas Semiconductor * shall not be used except as stated in the Dallas Semiconductor * Branding Policy. *--------------------------------------------------------------------------- */package com.dalsemi.onewire.utils;/** * CRC16 is a class containing an implementation of the * Cyclic-Redundency-Check (CRC) CRC16.  The CRC16 is used in * iButton memory packet structure. * <p> * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1. * * @version    0.00, 28 Aug 2000 * @author     DS */public class CRC16{   //--------   //-------- Variables   //--------   /**    * used in CRC16 calculation    */   private static final int[] ODD_PARITY =   {      0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0   };   //--------   //-------- Constructor   //--------   /**    * Private constructor to prevent instantiation.    */   private CRC16 ()   {   }   //--------   //-------- Methods   //--------   /**    * Perform the CRC16 on the data element based on a zero seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param  dataToCrc     data element on which to perform the CRC16    * @return  CRC16 value    */   public static int compute (int dataToCrc)   {      return compute(dataToCrc, 0);   }   /**    * Perform the CRC16 on the data element based on the provided seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param  dataToCrc     data element on which to perform the CRC16    * @return  CRC16 value    */   public static int compute (int dataToCrc, int seed)   {      int dat = ((dataToCrc ^ (seed & 0xFF)) & 0xFF);      seed = (seed&0xFFFF) >>> 8;      int indx1 = (dat & 0x0F);      int indx2 = (dat >>> 4);      if ((ODD_PARITY [indx1] ^ ODD_PARITY [indx2]) == 1)         seed = seed ^ 0xC001;      dat  = (dat << 6);      seed = seed ^ dat;      dat  = (dat << 1);      seed = seed ^ dat;      return seed;   }   /**    * Perform the CRC16 on an array of data elements based on a    * zero seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param   dataToCrc   array of data elements on which to perform the CRC16    *    * @return  CRC16 value    */   public static int compute (byte dataToCrc [])   {      return compute(dataToCrc, 0, dataToCrc.length, 0);   }   /**    * Perform the CRC16 on an array of data elements based on a    * zero seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param   dataToCrc   array of data elements on which to perform the CRC16    * @param   off         offset into the data array    * @param   len         length of data to CRC16    *    * @return  CRC16 value    */   public static int compute (byte dataToCrc [], int off, int len)   {      return compute(dataToCrc, off, len, 0);   }   /**    * Perform the CRC16 on an array of data elements based on the    * provided seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param   dataToCrc   array of data elements on which to perform the CRC16    * @param   off         offset into the data array    * @param   len         length of data to CRC16    * @param   seed        seed to use for CRC16    *    * @return  CRC16 value    */   public static int compute (byte dataToCrc [], int off, int len, int seed)   {      // loop to do the crc on each data element      for (int i = 0; i < len; i++)         seed = compute(dataToCrc [i + off], seed);      return seed;   }   /**    * Perform the CRC16 on an array of data elements based on the    * provided seed.    * <p>    * CRC16 is based on the polynomial = X^16 + X^15 + X^2 + 1.    *    * @param   dataToCrc   array of data elements on which to perform the CRC16    * @param   seed        seed to use for CRC16    * @return  CRC16 value    */   public static int compute (byte dataToCrc [], int seed)   {      return compute(dataToCrc, 0, dataToCrc.length, seed);   }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -