欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解

 更新時(shí)間:2017年08月09日 09:38:06   作者:Yanci516  
這篇文章主要介紹了Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解的相關(guān)資料,主要是利用Collections.sort()方法對泛型為String的List 進(jìn)行排序,需要的朋友可以參考下

Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解

利用Collections.sort()方法對泛型為String的List 進(jìn)行排序。具體要求:

1.創(chuàng)建完List<String>之后,往其中添加十條隨機(jī)字符串
2.每條字符串的長度為10以內(nèi)的隨機(jī)整數(shù)
3.每條字符串的每個(gè)字符都為隨機(jī)生成的字符,字符可以重疊
4.每條隨機(jī)字符串不可重復(fù)

將涉及到的知識(shí)有: String、StringBuffer、ListArray、泛型、Collections.sort、foreach、Random等相關(guān)知識(shí),算是 在JAVA 學(xué)習(xí)過程中一個(gè)比較好的的實(shí)踐。

1. 隨機(jī)生成一個(gè)字符

1.1 先將所有的字母和0-9的數(shù)字存放于一個(gè)字符串中,以便后續(xù)使用。

String str = "aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStT
       uUvVwWxXyYzZ0123456789";

1.2 因?yàn)橐獫M足隨機(jī)性,所以創(chuàng)建一個(gè) Random 對象,利用其中的 nextInt(str.length) 方法生成一個(gè) 0 — str.length 的隨機(jī)數(shù)。

Random random = new Random();
int index = random.nextInt(str.length());

1.3 再將上述生成的隨機(jī)數(shù)作為 str 字符串的索引取出相應(yīng)的字符,及隨機(jī)生成了一個(gè)字符

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ù)

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ī)字符串

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)過上述的兩個(gè)步驟,再在外部嵌套一個(gè) for 循環(huán)就可以生成 10 條隨機(jī)字符串

4. 創(chuàng)建一個(gè) ListArray<String> 集合儲(chǔ)存著10條隨機(jī)字符串

4.1 創(chuàng)建一個(gè) String 類型集合,該步奏應(yīng)該和步奏3同步完成

List<String> listString = new ArrayList<String>();

4.2 將每次生成的一條字符串添加到集合中,注意利用集合的 Contains() 方法判斷集合中之前是否已存在相同的字符串(雖然概率很小)。

//判斷當(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

總的代碼

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 的某個(gè)索引,以獲取相應(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ū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • Java數(shù)據(jù)結(jié)構(gòu)之二叉搜索樹詳解

    Java數(shù)據(jù)結(jié)構(gòu)之二叉搜索樹詳解

    二叉搜索樹作為一個(gè)經(jīng)典的數(shù)據(jù)結(jié)構(gòu),具有鏈表的快速插入與刪除的特點(diǎn),同時(shí)查詢效率也很優(yōu)秀,所以應(yīng)用十分廣泛。本文將詳細(xì)講講二叉搜索樹的原理與實(shí)現(xiàn),需要的可以參考一下
    2022-06-06
  • SpringMVC靜態(tài)資源配置過程詳解

    SpringMVC靜態(tài)資源配置過程詳解

    在javaweb項(xiàng)目中配置了DispatcherServlet的情況下,如果不進(jìn)行額外配置的話,幾乎所有的請求都會(huì)走這個(gè)servlet來處理,默認(rèn)靜態(tài)資源按路徑是訪問不到的會(huì)報(bào)404錯(cuò)誤,下面就來講一講如何配置才能訪問到靜態(tài)資源吧
    2022-08-08
  • 詳解JAVA 強(qiáng)引用

    詳解JAVA 強(qiáng)引用

    這篇文章主要介紹了JAVA 強(qiáng)引用的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-08-08
  • Spring Boot 單元測試JUnit的實(shí)踐

    Spring Boot 單元測試JUnit的實(shí)踐

    JUnit是一款優(yōu)秀的開源Java單元測試框架,也是目前使用率最高最流行的測試框架,這篇文章主要介紹了Spring Boot 單元測試JUnit的實(shí)踐,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 整理Java編程中字符串的常用操作方法

    整理Java編程中字符串的常用操作方法

    這篇文章主要介紹了Java編程中字符串的常用操作方法的整理,字符串處理是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2016-02-02
  • 使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者

    使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者

    這篇文章主要介紹了使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java異常的處理機(jī)制

    Java異常的處理機(jī)制

    這篇文章主要介紹了Java異常的處理機(jī)制,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 利用POI生成EXCEL文件的方法實(shí)例

    利用POI生成EXCEL文件的方法實(shí)例

    Apache POI 是用Java編寫的免費(fèi)開源的跨平臺(tái)的 Java API,Apache POI提供API給Java程式對Microsoft Office格式檔案讀和寫的功能,下面這篇文章主要給大家介紹了關(guān)于利用POI生成EXCEL文件的相關(guān)資料,需要的朋友可以參考下
    2018-07-07
  • Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例

    Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例

    Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例,需要的朋友可以參考一下
    2013-04-04
  • Java-文件File簡單實(shí)用方法(分享)

    Java-文件File簡單實(shí)用方法(分享)

    下面小編就為大家?guī)硪黄狫ava-文件File簡單實(shí)用方法(分享)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論