有一个需求,需要随机生成六位数,从100001 ---999999 但是又要不重复,且不影响性能。如果每次生成都去判断是否重复,当生成的次数足够多,会影响性能。
我想的是开一条线程,提前去处理。 提前生成好随机的数。直接用就好了
package cn.silence.random;
import cn.hutool.core.util.RandomUtil;
import java.util.ArrayList;
import java.util.List;
public class CodeRandom {
private final List<Integer> list = new ArrayList<>(1000000);
private int index = 0;
public void start() {
while (list.size() < 1000000) {
int code = RandomUtil.randomInt(100000, 999999);
if (!list.contains(code)) {
list.add(code);
}
}
}
public Integer getCode() {
if (index >= list.size()) {
return RandomUtil.randomInt(100000, 999999);
}
return list.get(index++);
}
}
CodeRandom codeRandom = new CodeRandom();
//启动线程
new Thread(codeRandom::start).start();
只取,不删,所以不涉及线程安全问题。如果删了list的话,后面生成的数可能导致重复