有一个需求,需要随机生成六位数,从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的话,后面生成的数可能导致重复