java隨機(jī)數(shù)生產(chǎn)算法實(shí)例
java提供了Math.random()函數(shù),返回一個(gè)double類型的隨機(jī)數(shù),也有util包里的Random類,可以生成double,int,float,long,bytes等隨機(jī)數(shù)。
但有些業(yè)務(wù)需求,往往需要對(duì)這些方法做一下封裝。比如用固定因子生成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"; /** * 返回一個(gè)定長(zhǎng)的帶因子的固定的隨機(jī)字符串(只包含大小寫字母、數(shù)字) * * @param length * 隨機(jī)字符串長(zhǎng)度 * @return 隨機(jī)字符串 */ 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(); } /** * 返回一個(gè)定長(zhǎng)的隨機(jī)字符串(只包含大小寫字母、數(shù)字) * * @param length * 隨機(jī)字符串長(zhǎng)度 * @return 隨機(jī)字符串 */ 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(); } /** * 返回一個(gè)定長(zhǎng)的隨機(jī)純字母字符串(只包含大小寫字母) * * @param length * 隨機(jī)字符串長(zhǎng)度 * @return 隨機(jī)字符串 */ 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(); } /** * 返回一個(gè)定長(zhǎng)的隨機(jī)純大寫字母字符串(只包含大小寫字母) * * @param length * 隨機(jī)字符串長(zhǎng)度 * @return 隨機(jī)字符串 */ public static String generateLowerString(int length) { return generateMixString(length).toLowerCase(); } /** * 返回一個(gè)定長(zhǎng)的隨機(jī)純小寫字母字符串(只包含大小寫字母) * * @param length * 隨機(jī)字符串長(zhǎng)度 * @return 隨機(jī)字符串 */ public static String generateUpperString(int length) { return generateMixString(length).toUpperCase(); } /** * 生成一個(gè)定長(zhǎng)的純0字符串 * * @param length * 字符串長(zhǎng)度 * @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ù)字生成一個(gè)定長(zhǎng)的字符串,長(zhǎng)度不夠前面補(bǔ)0 * * @param num * 數(shù)字 * @param fixdlenth * 字符串長(zhǎng)度 * @return 定長(zhǎng)的字符串 */ 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)化為長(zhǎng)度為" + fixdlenth + "的字符串發(fā)生異常!"); } sb.append(strNum); return sb.toString(); } /** * 每次生成的len位數(shù)都不相同 * * @param param * @return 定長(zhǎng)的數(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;// 測(cè)試因子比生產(chǎn)因子少1 System.out.println("返回一個(gè)定長(zhǎng)的帶因子的固定的隨機(jī)字符串(只包含大小寫字母、數(shù)字):" + generateStringByKey(32, channel)); System.out.println("返回一個(gè)定長(zhǎng)的隨機(jī)字符串(只包含大小寫字母、數(shù)字):" + generateString(32)); System.out.println("返回一個(gè)定長(zhǎng)的隨機(jī)純字母字符串(只包含大小寫字母):" + generateMixString(10)); System.out.println("返回一個(gè)定長(zhǎng)的隨機(jī)純大寫字母字符串(只包含大小寫字母):" + generateLowerString(10)); System.out.println("返回一個(gè)定長(zhǎng)的隨機(jī)純小寫字母字符串(只包含大小寫字母):" + generateUpperString(10)); System.out.println("生成一個(gè)定長(zhǎng)的純0字符串:" + generateZeroString(10)); System.out.println("根據(jù)數(shù)字生成一個(gè)定長(zhǎng)的字符串,長(zhǎng)度不夠前面補(bǔ)0:" + toFixdLengthString(123, 10)); int[] in = { 1, 2, 3, 4, 5, 6, 7 }; System.out.println("每次生成的len位數(shù)都不相同:" + getNotSimple(in, 3)); } }
運(yùn)行效果如下:
以上這篇java隨機(jī)數(shù)生產(chǎn)算法實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Java隨機(jī)數(shù)算法原理與實(shí)現(xiàn)方法實(shí)例詳解
- java生成抽樣隨機(jī)數(shù)的多種算法
- 史上最全的java隨機(jī)數(shù)生成算法分享
- Java一個(gè)簡(jiǎn)單的紅包生成算法
- Java排序算法之堆排思想及代碼實(shí)現(xiàn)
- Java計(jì)算器核心算法代碼實(shí)現(xiàn)
- Java利用遞歸算法實(shí)現(xiàn)查詢斐波那契數(shù)
- Java垃圾回收之分代收集算法詳解
- Java垃圾回收之標(biāo)記壓縮算法詳解
- Java實(shí)現(xiàn)獲取指定個(gè)數(shù)的不同隨機(jī)數(shù)
相關(guān)文章
springboot臨時(shí)文件存儲(chǔ)目錄配置方式
這篇文章主要介紹了springboot臨時(shí)文件存儲(chǔ)目錄配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07淺談java+內(nèi)存分配及變量存儲(chǔ)位置的區(qū)別
下面小編就為大家?guī)硪黄獪\談java+內(nèi)存分配及變量存儲(chǔ)位置的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08Java求解兩個(gè)非負(fù)整數(shù)最大公約數(shù)算法【循環(huán)法與遞歸法】
這篇文章主要介紹了Java求解兩個(gè)非負(fù)整數(shù)最大公約數(shù)算法,結(jié)合實(shí)例形式分析了java求解最大公約數(shù)的實(shí)現(xiàn)方法,并附帶了循環(huán)法與遞歸法算法思路,需要的朋友可以參考下2018-03-03Java 采用反射獲取class屬性值的實(shí)現(xiàn)代碼
以下是對(duì)在Java中采用反射獲取class屬性值的實(shí)現(xiàn)代碼進(jìn)行了分析介紹,需要的朋友可以過來參考下2013-08-08詳細(xì)解讀Druid數(shù)據(jù)庫連接池的使用
這篇文章主要介紹了Druid數(shù)據(jù)庫連接池的使用,數(shù)據(jù)庫連接池負(fù)責(zé)分配、管理和釋放數(shù)據(jù)庫連接,它允許應(yīng)用程序重復(fù)使用一個(gè)現(xiàn)有的數(shù)據(jù)庫連接,而不是重新建立一個(gè),需要的朋友可以參考下2023-03-03