From f2bfa6a1be8c028e732e01add8ce735bbacd3f56 Mon Sep 17 00:00:00 2001 From: Pusty Date: Tue, 3 Oct 2017 03:57:28 +0200 Subject: [PATCH] crc32 implementation --- Misc/crc32.java | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 Misc/crc32.java diff --git a/Misc/crc32.java b/Misc/crc32.java new file mode 100644 index 000000000..443b70bab --- /dev/null +++ b/Misc/crc32.java @@ -0,0 +1,28 @@ +import java.util.BitSet; + +//Generates a crc32 checksum for a given string or byte array +public class crc32 { + + public static void main(String[] args) { + System.out.println(Integer.toHexString(crc32("Hello World"))); + } + + public static int crc32(String str) { + return crc32(str.getBytes()); + } + + public static int crc32(byte[] data) { + BitSet bitSet = BitSet.valueOf(data); + int crc32 = 0xFFFFFFFF; //initial value + for(int i=0;i>>31)&1) != (bitSet.get(i)?1:0)) + crc32 = (crc32 << 1) ^ 0x04C11DB7; //xoring with polynomial + else + crc32 = (crc32 << 1); + } + crc32 = crc32 ^ 0; + crc32 = Integer.reverse(crc32); //result reflect + return crc32 ^ 0xFFFFFFFF; //final xor value + } + +}