Java 生成隨機(jī)字符串數(shù)組的實(shí)例詳解
利用Collections.sort()方法對泛型為String的List 進(jìn)行排序。具體要求:
1.創(chuàng)建完List<String>之后,往其中添加十條隨機(jī)字符串
2.每條字符串的長度為10以內(nèi)的隨機(jī)整數(shù)
3.每條字符串的每個字符都為隨機(jī)生成的字符,字符可以重疊
4.每條隨機(jī)字符串不可重復(fù)
將涉及到的知識有: String、StringBuffer、ListArray、泛型、Collections.sort、foreach、Random等相關(guān)知識,算是 在JAVA 學(xué)習(xí)過程中一個比較好的的實(shí)踐。
1. 隨機(jī)生成一個字符
1.1 先將所有的字母和0-9的數(shù)字存放于一個字符串中,以便后續(xù)使用。
1
2
|
String str = "aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStT uUvVwWxXyYzZ0123456789"; |
1.2 因?yàn)橐獫M足隨機(jī)性,所以創(chuàng)建一個 Random 對象,利用其中的 nextInt(str.length) 方法生成一個 0 — str.length 的隨機(jī)數(shù)。
1
2
|
Random random = new Random(); int index = random.nextInt(str.length()); |
1.3 再將上述生成的隨機(jī)數(shù)作為 str 字符串的索引取出相應(yīng)的字符,及隨機(jī)生成了一個字符
1
|
char c = str.charAt(index); |
2. 生成一條長度為10以內(nèi)的隨機(jī)字符串
2.1 因?yàn)槭?0以內(nèi)且滿足隨機(jī)性,所以此處使用 Math.random() 函數(shù),其返回值為隨機(jī) 0.0 - 1.0 的 Double 類型的數(shù)
1
2
3
|
StringBuffer stringBuffer = new StringBuffer(); //確定字符串長度 int stringLength = ( int ) (Math.random()* 10 ); |
2.2 現(xiàn)在字符串的長度可以確認(rèn),也實(shí)現(xiàn)了生成隨機(jī)的字符,再利用 for 循環(huán)就可以生成一條長度為10以內(nèi)的隨機(jī)字符串
1
2
3
4
5
6
7
|
for ( int j = 0 ; j < stringLength; j++) { int index = random.nextInt(str.length()); char c = str.charAt(index); stringBuffer.append(c); } //將StringBuffer轉(zhuǎn)換為String類型的字符串 String string = stringBuffer.toString(); |
3. 生成10條隨機(jī)字符串
3.1 經(jīng)過上述的兩個步驟,再在外部嵌套一個 for 循環(huán)就可以生成 10 條隨機(jī)字符串
4. 創(chuàng)建一個 ListArray<String> 集合儲存著10條隨機(jī)字符串
4.1 創(chuàng)建一個 String 類型集合,該步奏應(yīng)該和步奏3同步完成
1
|
List<String> listString = new ArrayList<String>(); |
4.2 將每次生成的一條字符串添加到集合中,注意利用集合的 Contains() 方法判斷集合中之前是否已存在相同的字符串(雖然概率很小)。
1
2
3
4
5
6
7
|
//判斷當(dāng)前的list容器中是否已有剛生成的字符串,滿足每條字符串不可重復(fù)性 if (!(listString.contains(stringBuffer.toString()))){ listString.add(stringBuffer.toString()); } else { //i-- 如果不滿足則重新生成 i--; } |
5 最后對集合排序
5.1 調(diào)用 Collections.sort() 方法對集合排序,其排序的規(guī)則如下:
- 從左向右原則,且0-9
- 數(shù)字優(yōu)先原則,且A-Z
- 字母大寫優(yōu)先原則,且a-z
總的代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.List; import java.util.Random; public class RandomString { public static void main(String[] args) { List<String> strList = randomString(); System.out.println( "------隨機(jī)生成的10條字符串-------" ); for (String string : strList) { System.out.println(string); } System.out.println( "------------排序后------------" ); Collections.sort(strList); for (String string : strList) { System.out.println(string); } } public static List<String> randomString(){ //將所有的大小寫字母和0-9數(shù)字存入字符串中 String str = "aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ0123456789" ; Random random = new Random(); List<String> listString = new ArrayList<String>(); String strArray[ ] = new String[ 10 ]; //生成10條長度為1-10的隨機(jī)字符串 for ( int i = 0 ; i < 10 ; i++) { StringBuffer stringBuffer = new StringBuffer(); //確定字符串長度 int stringLength = ( int ) (Math.random()* 10 ); for ( int j = 0 ; j < stringLength; j++) { //先隨機(jī)生成初始定義的字符串 str 的某個索引,以獲取相應(yīng)的字符 int index = random.nextInt(str.length()); char c = str.charAt(index); stringBuffer.append(c); } //判斷當(dāng)前的list容器中是否已有剛生成的字符串,滿足每條字符串不可重復(fù)性 if (!(listString.contains(stringBuffer.toString()))) { listString.add(stringBuffer.toString()); } else { i--; } } return listString; } } |
輸出答案不唯一
以上就是Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
原文鏈接:http://www.jianshu.com/p/61db371f1635