当前位置:网站首页>random list随机生成不重复数

random list随机生成不重复数

2022-06-24 22:55:00 Silence丶你的名字

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

原网站

版权声明
本文为[Silence丶你的名字]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_42553504/article/details/125077595