Java计算一个字符串的HashCode

计算hashcode的原理步详解:

import java.math.BigInteger;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;


public class MD5 {
    public static void main(String[] args) throws NoSuchAlgorithmException{
        /*
        * MD5,Message Digest Algorithm 5,是一种被广泛使用的信息摘要算法,
        * 可以将给定的任意长度数据通过一定的算法计算得出一个 128 位固定长度的散列值
        */

        // 第一步,获取MessageDigest对象,参数为MD5字符串,表示这是一个MD5算法
        MessageDigest md5 = MessageDigest.getInstance("MD5");
    
        // 第二步,输入源数据,参数类型为byte[]
        md5.update(new byte[] {'1', '2', '3'});
    
        // 第三步,计算MD5值 
        // String resultArray = md5.digest().toString();
        /*
        * digest() 方法返回值是一个字节数组类型的 16 位长度的哈希值,通常,我们会
        * 转化为十六进制的 32 位长度的字符串来使用,可以利用 BigInteger 类来做这个转化:
        */
        BigInteger bigInt = new BigInteger(1, md5.digest());
        String resultStr = bigInt.toString(16);

        System.out.print("123的MD5为:");
        System.out.println(resultStr);
        System.out.println(resultStr.length());
    }

}

 

由于Java中的String对象采用的是Unicode编码,及一个字符(同char一样)占两个字节,不过通过string的内置方法获取byte[]的时候,Java会自动将空的字节去除。如下:

String str1 = "123";  //数据在内存空间中占用6个字节的空间

String Str2 = "王";  //数据在内存空间中占用2个字节

int ln1 = str1.getBytes().length;  //ln1的长度为3(空的字节自动被舍弃)

int ln2 = str2.getBytes().length;  //ln2的长度为2(中文字符编码要占用两个字节)

 

所以计算一个数字字符串的时候可以将步骤2的代码作为如下修改即可

String str = "123456";

md5.update(str.getBytes());

 

 

你可能感兴趣的:(JAVA)