我有一个名为Student
的对象,它有studentName
,studentId
,studentAddress
等。对于studentId
,我必须随机生成字符串由七个数字字符组成,
例如
studentId = getRandomId();
studentId = "1234567" <-- from the random generator.
我必须确保没有重复的ID。
答案 0 :(得分:129)
生成随机字符串很简单 - 只需使用java.util.Random
和包含您想要的所有字符的字符串,例如。
public static String generateString(Random rng, String characters, int length)
{
char[] text = new char[length];
for (int i = 0; i < length; i++)
{
text[i] = characters.charAt(rng.nextInt(characters.length()));
}
return new String(text);
}
现在,为了获得唯一性,您需要将生成的字符串存储在某处。你如何做到这将取决于你的应用程序的其余部分。
答案 1 :(得分:52)
这非常好:
如果您想要唯一性(很有可能),请考虑使用MD5或SHA哈希值。
答案 2 :(得分:17)
您还可以使用java.util包中的UUID类,它返回32位字符String的随机uuid。
java.util.UUID.randomUUID().toString()
答案 3 :(得分:5)
Random ran = new Random();
int top = 3;
char data = ' ';
String dat = "";
for (int i=0; i<=top; i++) {
data = (char)(ran.nextInt(25)+97);
dat = data + dat;
}
System.out.println(dat);
答案 4 :(得分:2)
我认为以下类代码会对您有所帮助。它支持多线程,但你可以做一些改进,比如删除同步块和同步到getRandomId()方法。
public class RandomNumberGenerator {
private static final Set<String> generatedNumbers = new HashSet<String>();
public RandomNumberGenerator() {
}
public static void main(String[] args) {
final int maxLength = 7;
final int maxTry = 10;
for (int i = 0; i < 10; i++) {
System.out.println(i + ". studentId=" + RandomNumberGenerator.getRandomId(maxLength, maxTry));
}
}
public static String getRandomId(final int maxLength, final int maxTry) {
final Random random = new Random(System.nanoTime());
final int max = (int) Math.pow(10, maxLength);
final int maxMin = (int) Math.pow(10, maxLength-1);
int i = 0;
boolean unique = false;
int randomId = -1;
while (i < maxTry) {
randomId = random.nextInt(max - maxMin - 1) + maxMin;
synchronized (generatedNumbers) {
if (generatedNumbers.contains(randomId) == false) {
unique = true;
break;
}
}
i++;
}
if (unique == false) {
throw new RuntimeException("Cannot generate unique id!");
}
synchronized (generatedNumbers) {
generatedNumbers.add(String.valueOf(randomId));
}
return String.valueOf(randomId);
}
}
答案 5 :(得分:1)
您需要问的第一个问题是您是否真的需要ID是随机的。有时,顺序ID就足够了。
现在,如果你确实需要它是随机的,我们首先注意到生成的不包含重复项的数字序列不能被称为随机数。 :p现在我们已经解决了这个问题,最快的方法是让Hashtable
或HashMap
包含已经生成的所有ID。每当生成新ID时,请根据哈希表对其进行检查,如果ID已经出现则重新生成。如果学生人数远远少于ID的范围,这通常会很有效。如果不是,则由于需要重新生成ID的概率增加,您陷入更深的麻烦,P(生成新ID)= number_of_id_already_generated / number_of_all_possible_ids。在这种情况下,请检查第一段(您是否需要ID是随机的?)。
希望这有帮助。
答案 6 :(得分:1)
许多可能性......
你知道如何随机生成一个整数吗? 因此,您可以从中生成一个字符...(ex 65 - &gt; A)
这取决于你需要什么,随机性的水平,涉及的安全性......但是对于一个学校项目我猜想UUID子串适合:)