#ifndef RNG_H
#define RNG_H
#include <memory>
#include <random>
namespace rng
{
using namespace std;
const static size_t MAXRAND = random_device::max();
class RNG
{
private:
random_device m_rd;
shared_ptr<mt19937>m_regen;
shared_ptr<uniform_int_distribution<size_t> >m_dist;
RNG() noexcept;
public:
static RNG &getInstance();
size_t getInteger() noexcept;
};
size_t getRand(size_t r);
}
#endif
#include "RNG.h"
namespace rng
{
RNG::RNG() noexcept
{
m_regen = make_shared<mt19937>(m_rd());
m_dist = make_shared<uniform_int_distribution<size_t> >(0, MAXRAND);
}
RNG & RNG::getInstance()
{
static RNG instance;
return instance;
}
size_t RNG::getInteger() noexcept
{
return (*m_dist)(*m_regen);
}
size_t getRand(size_t r)
{
return RNG::getInstance().getInteger() % r;
}
}
/****************************************************************************
@File Name: test.cpp
@Author: binwang
@mail: binwang@trendmicro.com.cn
@Created Time: Sat 04 Feb 2017 12:58:48 AM CST
****************************************************************************/
#include <iostream>
#include "RNG.h"
using namespace rng;
int main(int argc, char **argv)
{
for(int i = 0;i < 10;i++) cout << getRand(1000) << endl;
return 0;
}
CC=g++
all:
$(CC) -std=c++11 -g -o test test.cpp RNG.h RNG.cpp
random
最新推荐文章于 2025-08-11 23:59:18 发布
本文介绍了一个简单的随机数生成器的实现方法,该生成器基于Mersenne Twister算法并通过C++11标准库实现。文章提供了完整的源代码示例,展示了如何创建一个线程安全的单例模式随机数生成器,并提供了获取指定范围内的随机整数的方法。

1980

被折叠的 条评论
为什么被折叠?



