java隨機數(shù)生產(chǎn)算法實例
更新時間:2017年10月07日 10:20:30 作者:shindoyang
下面小編就為大家?guī)硪黄猨ava隨機數(shù)生產(chǎn)算法實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
java提供了Math.random()函數(shù),返回一個double類型的隨機數(shù),也有util包里的Random類,可以生成double,int,float,long,bytes等隨機數(shù)。
但有些業(yè)務需求,往往需要對這些方法做一下封裝。比如用固定因子生成32位的3DES算法key值。
下面提供一些封裝的方法:
package test;
import java.util.Random;
public class RandomUtil {
public static final String ALLCHAR = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
public static final String LETTERCHAR = "abcdefghijkllmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
public static final String NUMBERCHAR = "0123456789";
/**
* 返回一個定長的帶因子的固定的隨機字符串(只包含大小寫字母、數(shù)字)
*
* @param length
* 隨機字符串長度
* @return 隨機字符串
*/
public static String generateStringByKey(int length, int channel) {
StringBuffer sb = new StringBuffer();
Random random = new Random(channel);
for (int i = 0; i < length; i++) {
sb.append(ALLCHAR.charAt(random.nextInt(ALLCHAR.length())));
}
return sb.toString();
}
/**
* 返回一個定長的隨機字符串(只包含大小寫字母、數(shù)字)
*
* @param length
* 隨機字符串長度
* @return 隨機字符串
*/
public static String generateString(int length) {
StringBuffer sb = new StringBuffer();
Random random = new Random();
for (int i = 0; i < length; i++) {
sb.append(ALLCHAR.charAt(random.nextInt(ALLCHAR.length())));
}
return sb.toString();
}
/**
* 返回一個定長的隨機純字母字符串(只包含大小寫字母)
*
* @param length
* 隨機字符串長度
* @return 隨機字符串
*/
public static String generateMixString(int length) {
StringBuffer sb = new StringBuffer();
Random random = new Random();
for (int i = 0; i < length; i++) {
sb.append(ALLCHAR.charAt(random.nextInt(LETTERCHAR.length())));
}
return sb.toString();
}
/**
* 返回一個定長的隨機純大寫字母字符串(只包含大小寫字母)
*
* @param length
* 隨機字符串長度
* @return 隨機字符串
*/
public static String generateLowerString(int length) {
return generateMixString(length).toLowerCase();
}
/**
* 返回一個定長的隨機純小寫字母字符串(只包含大小寫字母)
*
* @param length
* 隨機字符串長度
* @return 隨機字符串
*/
public static String generateUpperString(int length) {
return generateMixString(length).toUpperCase();
}
/**
* 生成一個定長的純0字符串
*
* @param length
* 字符串長度
* @return 純0字符串
*/
public static String generateZeroString(int length) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < length; i++) {
sb.append('0');
}
return sb.toString();
}
/**
* 根據(jù)數(shù)字生成一個定長的字符串,長度不夠前面補0
*
* @param num
* 數(shù)字
* @param fixdlenth
* 字符串長度
* @return 定長的字符串
*/
public static String toFixdLengthString(long num, int fixdlenth) {
StringBuffer sb = new StringBuffer();
String strNum = String.valueOf(num);
if (fixdlenth - strNum.length() >= 0) {
sb.append(generateZeroString(fixdlenth - strNum.length()));
} else {
throw new RuntimeException("將數(shù)字" + num + "轉(zhuǎn)化為長度為" + fixdlenth + "的字符串發(fā)生異常!");
}
sb.append(strNum);
return sb.toString();
}
/**
* 每次生成的len位數(shù)都不相同
*
* @param param
* @return 定長的數(shù)字
*/
public static int getNotSimple(int[] param, int len) {
Random rand = new Random();
for (int i = param.length; i > 1; i--) {
int index = rand.nextInt(i);
int tmp = param[index];
param[index] = param[i - 1];
param[i - 1] = tmp;
}
int result = 0;
for (int i = 0; i < len; i++) {
result = result * 10 + param[i];
}
return result;
}
public static void main(String[] args) {
int channel = 555555;// 測試因子比生產(chǎn)因子少1
System.out.println("返回一個定長的帶因子的固定的隨機字符串(只包含大小寫字母、數(shù)字):" + generateStringByKey(32, channel));
System.out.println("返回一個定長的隨機字符串(只包含大小寫字母、數(shù)字):" + generateString(32));
System.out.println("返回一個定長的隨機純字母字符串(只包含大小寫字母):" + generateMixString(10));
System.out.println("返回一個定長的隨機純大寫字母字符串(只包含大小寫字母):" + generateLowerString(10));
System.out.println("返回一個定長的隨機純小寫字母字符串(只包含大小寫字母):" + generateUpperString(10));
System.out.println("生成一個定長的純0字符串:" + generateZeroString(10));
System.out.println("根據(jù)數(shù)字生成一個定長的字符串,長度不夠前面補0:" + toFixdLengthString(123, 10));
int[] in = { 1, 2, 3, 4, 5, 6, 7 };
System.out.println("每次生成的len位數(shù)都不相同:" + getNotSimple(in, 3));
}
}
運行效果如下:

以上這篇java隨機數(shù)生產(chǎn)算法實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談java+內(nèi)存分配及變量存儲位置的區(qū)別
下面小編就為大家?guī)硪黄獪\談java+內(nèi)存分配及變量存儲位置的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
Java求解兩個非負整數(shù)最大公約數(shù)算法【循環(huán)法與遞歸法】
這篇文章主要介紹了Java求解兩個非負整數(shù)最大公約數(shù)算法,結(jié)合實例形式分析了java求解最大公約數(shù)的實現(xiàn)方法,并附帶了循環(huán)法與遞歸法算法思路,需要的朋友可以參考下2018-03-03
Java 采用反射獲取class屬性值的實現(xiàn)代碼
以下是對在Java中采用反射獲取class屬性值的實現(xiàn)代碼進行了分析介紹,需要的朋友可以過來參考下2013-08-08

