java生成随机数(字符串)示例分享_java

用来生成简单的随机java生成随机数,大小+数字。没特符

复制代码 代码如下:

package passwords;
import java.util.Random;
public class pwdGen {
 private Random rdseed=new Random();

 /**
  *@param
  *length  password length;
  *@param
  *letters  boolean non-capital letters combination control;
  *@param
  *letters_capi boolean capital letters combination control;
  *@param
  *numbers  boolean capital letters combination control;
  */
 public  String getpwd(int length,boolean letters,boolean letters_capi,boolean numbers){
  String res="";
  Random rd=this.rdseed;
  while(length-->0){
   char _1dgt=0;
   if(letters&&letters_capi&&numbers){
    int _key=rd.nextInt(3);
    if(2==_key){
     _1dgt=get_L();
    }else if(1==_key){
     _1dgt=get_L_C();
    }else if(0==_key){
     _1dgt=get_N();
    }
   }else if(letters&&letters_capi&&!numbers){
    int _key=rd.nextInt(2);
    if(1==_key){
     _1dgt=get_L();
    }else if(0==_key){
     _1dgt=get_L_C();
    }
   }else if(!letters&&letters_capi&&numbers){
    int _key=rd.nextInt(2);
    if(1==_key){
     _1dgt=get_N();
    }else if(0==_key){
     _1dgt=get_L_C();
    }
   }else if(letters&&!letters_capi&&numbers){
    int _key=rd.nextInt(2);
    if(1==_key){
     _1dgt=get_L();
    }else if(0==_key){
     _1dgt=get_N();
    }
   }else if(letters&&!letters_capi&&!numbers){
    _1dgt=get_L();
   }else if(!letters&&!letters_capi&&numbers){
    _1dgt=get_N();
   }else if(!letters&&letters_capi&&!numbers){
    _1dgt=get_L_C();
   }else{
    res=null;
    break;
   }
   res+=_1dgt;
  }
  return res ;
 }
 private char get_L_C(){
  Random rd=this.rdseed;
  int _dgt=(rd.nextInt(26)+65);
  return (char)_dgt;
 }
 private char get_N(){
  Random rd=this.rdseed;
  int _dgt=(rd.nextInt(10)+48);
  return (char)_dgt;
 }
 private char get_L(){
  Random rd=this.rdseed;
  int _dgt=(rd.nextInt(26)+97);
  return (char)_dgt;
 }
 private char get_S(){
  Random rd=this.rdseed;
  int _dgt=(rd.nextInt(14)+33);
  return (char)_dgt;
 }
 public static void main(String[] args) {
  pwdGen test= new pwdGen();

  int testct=1000000;

  long start=System.nanoTime();
  while(testct-->0){
    test.getpwd(10, true, true, true);
  }
  long end= System.nanoTime();
  System.out.println(((double)(end-start))/(1000000000));
  System.out.println(test.getpwd(10, true, true, true));
 }

}

时间: 2024-08-17 16:21:59

java生成随机数(字符串)示例分享_java的相关文章

java反射机制实战示例分享_java

首先,我们来认识几个类. Class(java.lang.Class) Class对象是一个特殊对象,每一个类都有一个Class对象,用来创建该类的"常规"对象.可以通过对象的getClass()方法获取. 比如我们运行这一行代码: 复制代码 代码如下: System.out.println("测试".getClass().toString()); 得到的结果就是: 复制代码 代码如下: class java.lang.String Field(java.lang.

java生成压缩文件示例代码_java

代码: 复制代码 代码如下: import java.io.BufferedOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream; import org.apache.tools.zip.ZipEntry;import org.apache.tools.zip.ZipOutputStream; /**  * @project: Test  * @author

java实现sunday算法示例分享_java

字符串匹配查找算法中,最著名的两个是KMP算法(Knuth-Morris-Pratt)和BM算法(Boyer-Moore).两个算法在最坏情况下均具有线性的查找时间.但是在实用上,KMP算法并不比最简单的C库函数strstr()快多少,而BM算法则往往比KMP算法快上3-5倍(未亲身实践).但是BM算法还不是最快的算法,这里介绍一种比BM算法更快一些的查找算法Sunday算法. Sunday算法的思想和BM算法中的坏字符思想非常类似.差别只是在于Sunday算法在匹配失败之后,是取目标串中当前和

java图片验证码实现示例分享_java

复制代码 代码如下: package com.sanrong;import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.Graphics2D;import java.awt.image.BufferedImage;import java.io.IOException;import java.util.Random; import javax.imageio.ImageIO;import

java实现动态代理示例分享_java

复制代码 代码如下: import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy; public class LogHandler implements InvocationHandler {    private Object delegate;     public Object bind(Object delegate) {       

java连接orcale数据库示例分享_java

database.properties 复制代码 代码如下: jdbc.driver_class=oracle.jdbc.driver.OracleDriverjdbc.connection.url=jdbc:oracle:thin:@localhost:1521:orcljdbc.connection.username=scottjdbc.connection.password=tiger ConfigManager.java 复制代码 代码如下: import java.io.IOExcep

java实现京东登陆示例分享_java

复制代码 代码如下: package com.lkb.test; import java.util.ArrayList;import java.util.HashMap;import java.util.Iterator;import java.util.List;import java.util.Map; import org.apache.http.HttpResponse;import org.apache.http.client.ResponseHandler;import org.ap

java使用颜色选择器示例分享_java

复制代码 代码如下: package com.liuxing.test;import java.awt.Color;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.JButton;import javax.swing.JColorChooser;import javax.swing.JFrame;import javax.swing.JLabel;import ja

java的arrays数组排序示例分享_java

Java API对Arrays类的说明是:此类包含用来操作数组(比如排序和搜索)的各种方法. 1.对基本数据类型的数组的排序 说明: (1)Arrays类中的sort()使用的是"经过调优的快速排序法"; (2)比如int[],double[],char[]等基数据类型的数组,Arrays类之只是提供了默认的升序排列,没有提供相应的降序排列方法. (3)要对基础类型的数组进行降序排序,需要将这些数组转化为对应的封装类数组,如Integer[],Double[],Character[]等