|  | // Copyright 2015 The Go Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style | 
|  | // license that can be found in the LICENSE file. | 
|  |  | 
|  | package crc32_test | 
|  |  | 
|  | import ( | 
|  | "fmt" | 
|  | "hash/crc32" | 
|  | ) | 
|  |  | 
|  | func ExampleMakeTable() { | 
|  | // In this package, the CRC polynomial is represented in reversed notation, | 
|  | // or LSB-first representation. | 
|  | // | 
|  | // LSB-first representation is a hexadecimal number with n bits, in which the | 
|  | // most significant bit represents the coefficient of x⁰ and the least significant | 
|  | // bit represents the coefficient of xⁿ⁻¹ (the coefficient for xⁿ is implicit). | 
|  | // | 
|  | // For example, CRC32-Q, as defined by the following polynomial, | 
|  | //	x³²+ x³¹+ x²⁴+ x²²+ x¹⁶+ x¹⁴+ x⁸+ x⁷+ x⁵+ x³+ x¹+ x⁰ | 
|  | // has the reversed notation 0b11010101100000101000001010000001, so the value | 
|  | // that should be passed to MakeTable is 0xD5828281. | 
|  | crc32q := crc32.MakeTable(0xD5828281) | 
|  | fmt.Printf("%08x\n", crc32.Checksum([]byte("Hello world"), crc32q)) | 
|  | // Output: | 
|  | // 2964d064 | 
|  | } |