C++时间管理和随机数

2023-05-16

时间段

#include <chrono>
	// duration TYPEDEFS
typedef duration<long long, nano> nanoseconds;  //纳秒
typedef duration<long long, micro> microseconds; //微秒
typedef duration<long long, milli> milliseconds; //毫秒
typedef duration<long long> seconds; //秒
typedef duration<int, ratio<60> > minutes; //分钟
typedef duration<int, ratio<3600> > hours; //小时
#include <chrono>
#include <iostream>
#include <thread>
using namespace std;
int main()
{
	chrono::duration<long long,ratio<3600> > dur;//构造对象
	chrono::hours h(1);
	this_thread::sleep_for(chrono::seconds(3));//延迟3秒
	chrono::seconds s(1000);
	chrono::seconds res = h - s;//时间段运算
	cout << res.count() << endl;//打印间隔
	return 0;
}

时钟

1.system_clock:获取系统时间,需要转换成time_t形式显示出来

2.steady_clock:计时

3.high_resolution_clock:高精度时钟

4.时钟类共用的一些函数

(1)static time_point now() 获取当前时间点

(2)static time64_t to_time_t(const time_point x);

(3)time_point from_time_t(time_t x);

#include <chrono>
#include <iostream>
#include <thread>
#include <iomanip>     //put_time()
using namespace std;
int main()
{
	//system_clock
	chrono::system_clock::time_point res = chrono::system_clock::now();//获取当前时间点
	time_t tt = chrono::system_clock::to_time_t(res);//转换为可以显示的时间戳
	cout << ctime(&tt) ;//转换为正确时间字符串打印出来
	struct std::tm* p = localtime(&tt);
	cout << "格式化时间:" << put_time(p,"%c") << endl;
	cout << res.time_since_epoch().count() << endl;//打印时间戳
	chrono::system_clock::time_point end = chrono::system_clock::now();//获取当前时间点
	auto dur = end - res;//获取时间间隔
	cout << dur.count() << endl;//纳秒
	//steady_clock
	chrono::steady_clock::time_point start = chrono::steady_clock::now();
	this_thread::sleep_for(chrono::seconds(1));
	chrono::steady_clock::time_point endt = chrono::steady_clock::now();
	chrono::duration<double,ratio<1>> timetemp = endt - start;//转换为秒
	cout << timetemp.count() << endl;
	//high_resolution_clock
	chrono::high_resolution_clock::time_point startime = chrono::high_resolution_clock::now();
	this_thread::sleep_for(chrono::seconds(1));
	chrono::high_resolution_clock::time_point endtime = chrono::high_resolution_clock::now();
	chrono::duration<double, ratio<1>> time = endtime - startime;//转换为秒
	cout << time.count() << endl;
	return 0;
}

时间转换

1.duration_cast不属于duration类(只有浮点时长和整数时长可以直接隐式转换)

2.time_point_cast不属于time_point(存在精度丢失使用)

#include <chrono>
#include <iostream>
#include <thread>
using namespace std;
//辅助模板打印函数
template <class Dur>
void print_time(chrono::time_point<chrono::high_resolution_clock, Dur> time_point)
{
	cout << time_point.time_since_epoch().count() << endl;
}
int main()
{
	//duration_cast
	chrono::high_resolution_clock::time_point start = chrono::high_resolution_clock::now();
	this_thread::sleep_for(chrono::seconds(1));
	auto end = chrono::high_resolution_clock::now();
	chrono::milliseconds dtime = chrono::duration_cast<chrono::milliseconds>(end - start);
	cout << dtime.count() << endl;;
	chrono::duration<double, ratio<1, 1000>> dtime1 = end - start;//浮点型隐式转换
	cout << dtime1.count() << endl;
	//time_point_cast
	using TIMEMS = chrono::time_point<chrono::high_resolution_clock, chrono::milliseconds>;
	TIMEMS time_point_sec(chrono::seconds(6));
	TIMEMS time_point_ms(time_point_sec);//秒到毫秒
	using TIMESEC = chrono::time_point<chrono::high_resolution_clock, chrono::seconds>;
	TIMEMS time_ms(chrono::milliseconds(6677));
	TIMESEC time_sec = chrono::time_point_cast<chrono::seconds>(time_ms);//毫秒到秒   6
	return 0;
}

随机种子序列:seed_seq

类似srand函数,用来设置范围

size():检测种子个数

generate()

param():做元素的拷贝

	seed_seq seed = { 1, 3, 5, 7, 9, 2, 4, 6, 8 };
	cout << seed.size() << endl;//9
	array<int, 9> data;
	seed.param(data.begin());

引擎适配器

shuffle_order_engine:乱序随机数引擎适配器

independent_bits_engine:独立位随机数引擎适配器

discard_block_engine:丢弃快随机数引擎适配器

default_random_engine:默认随机数引擎适配器

#include <random>
#include <iostream>
#include <chrono>
#include <functional>
using namespace std;
int main()
{
	//1.生成随机数
	default_random_engine e;
	e.seed((size_t)chrono::high_resolution_clock::now().time_since_epoch().count());
	//e.seed((size_t)time(NULL));
	cout << e.max() << endl;//最大
	cout << e.min() << endl;//最小
	//2.分布方式和引擎方式
	uniform_int_distribution<int> dur(1, 6);//只生成1—6的随机数
	cout << dur(e) << endl;
	auto randb = bind(dur, e);
	for (int i = 0; i < 5;i++)
	cout << (randb() + randb() + randb()) << endl;//重复生成随机数
	return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C++时间管理和随机数 的相关文章

  • java测试示例-生成ULID

    ULID全称Universally Unique Lexicographically Sortable Identifier xff0c 直译就是通用唯一按字典排序的标识符 xff0c 原始仓库是https github com ulid
  • jdk8-获取本机ip、判断ip范围、ip与long互转等

    在配置nginx的ip白名单时候 xff0c 会通过ip段进行配置 xff08 如 10 10 10 10 24 xff09 就在思考这种配置怎么通过代码解析并判断 xff0c 故通过搜索网络内容 xff0c 并通过java编写测试代码 代
  • python3通过文件头判断文件类型

    最近 xff0c 在学习python3中 xff0c 感觉入门挺简单 xff0c 毕竟本身是java开发 xff0c 很多容易理解一些东西 这几天对文件类型的验证有点想法 xff0c 就在网上搜索 xff0c 是找到了很多博客 xff0c
  • mysql数据数据表的排序规则修改

    在工作中同事遇到的问题 xff0c 是找一种简便的方法批量修改数据表字段的排序规则 xff0c 在MySQL中叫collation xff0c 和编码CHARACTER一起出现的 collation有三种级别 xff0c 分辨是数据库级别
  • linux 普通用户sudo无需手动敲密码

    普通用户在执行一些root权限的操作时 xff0c 需要用到sudo命令来执行 xff0c 同时需要手动输入密码 xff0c 比较繁琐 xff0c 下面的操作来减少手动输入密码 1 visudo命令编辑 etc sudoers文件 sudo
  • Qt QFile 删除文件最后n个字节的数据

    QFile无需打开文件 xff0c 即可删除文件最后面的n个字节的数据 方法很简单 xff0c 可以通过QFile自带的resize函数进行大小的处理 resize size 如果 size的大小大于file的大小 xff0c file后面
  • Qt中通过C++ 实现udp广播报文

    Qt UDP消息交互 udp广播原理介绍客户端实现方法客户端思路实现代码 服务端实现方法服务端思路实现代码 udp广播原理介绍 UDP是面向非连接的网络交互协议 xff0c 在UDP交互中 xff0c 存在客户端和服务端 xff0c 客户端
  • 实现手机app和微信小程序和树莓派智能音箱远程控制arduino获取甲醛温湿度和控制灯(esp8266 ZE08-CH2O DHT11 MQTT 语音识别 语言合成 http请求转串口通信系统 )

    首先你有这样的esp8266 这种esp8266自身带2个按键和烧录芯片方便调试 xff0c 综合性价比较高 需要有一个arduino uno 连接甲醛探测器和温湿度探测器 或者其他芯片都行 还有就是你要有树莓派和usb麦克风 xff0c
  • 什么是法线贴图?

    什么是法线贴图技术呢 xff1f 这是一种用来实现3D效果的一种技术 xff0c 要想理解这种技术还请您听我慢慢道来 我们知道 xff0c 在游戏中经常会有这样的情况 xff0c 就是一个平面 这个平面在现实中并不是一 个 平 面 xff0
  • 串口中断收发定长数据

    一 实验设计效果 配置串口助手波特率为115200 xff0c 传输数据长度为8 Bit xff0c 无奇偶校验位 xff0c 1个停止位 xff1b 通过串口助手向MCU发送指定长度的字符串 xff0c MCU接收到指定长度的字符串后 x
  • Qt 中C++ async实现并行处理

    在项目中 xff0c 难免遇到性能问题 xff0c 为了提高处理的性能 xff0c 针对可以并行处理的部分单独提取出来 xff0c 利用并行编程来提高处理的速度 xff0c 从而实现高性能 C 43 43 11中有一个async 函数 xf
  • 深度学习环境入门之手写数字识别

    在自己的windows环境下配置好了深度学习的环境 xff0c 本文主要记录一下用深度学习的环境下实现一个简单的手写数字识别的模型训练和使用 1 在pycharm中配置conda环境 xff1a 环境配置好以后 xff0c 可以开始手写数字
  • 算法之KMP算法 全新思路介绍!

    KMP算法是一个经典的字符串匹配算法 xff0c 也是一种常用的字符串匹配算法 在KMP算法没出现之前 xff0c 大家在字符串匹配的时候 xff0c 都是两个for循环嵌套完成字符串之间的匹配 这种算法称作 BF算法 xff08 暴力求解
  • c++ linux utf-8 编码 中文汉字分割(超简单代码)

    UTF 8 编码对于英文字母 xff0c 占用一个字节 xff1b UTF 8 编码对于中文字母 xff0c 占用多个字节 xff0c 最大占用6个字节 xff0c 其中第一个字节二进制的最高位连续1的个数来表示占用字节的个数 xff0c
  • 算法之并查集

    并查集 xff0c 顾名思义 xff0c 就是合并不同的集合 xff0c 并查集是一种集合合并和查找算法 这是一种思想很奇妙的算法 xff0c 学会它 xff0c 在你后续的程序学习中可以有很多的可以用的地方 什么是并查集 xff1f 举个
  • 算法之主成分分析PCA详解(包含理论推导和代码)

    1 PCA介绍 主成分分析算法 xff08 Principal Component Analysis xff09 简称PCA xff0c 是一种常用的统计方法 该方法对高维的数据进行筛选 xff0c 选出最具有代表性最重要的的几维数据 xf
  • linux 命令行进行桌面图标的打开

    近期在处理一个需求 xff0c 需要在代码中打开桌面的某个图标 xff0c 因此 xff0c 做了一些搜索 xff0c 最终发现 xff0c 有两个比较好用的命令 xff0c 下面来讲解一下 1 gtk launch 在linux系统一般已
  • 算法之滑动窗口寻找最长无重复字符串

    今天无聊的时候刷了一道leetcode的题目 xff0c 给定字符串 xff0c 查找最长无重复字符串 xff0c 具体题目信息如下 xff1a 给定一个字符串 s xff0c 请你找出其中不含有重复字符的 最长子串 的长度 示例 1 输入
  • 算法之图解单纯形算法C++

    在之前的算法博客中 xff0c 结合案例和算法的图形表示 xff0c 获得了较多同学的好评 xff0c 例如之前写的迪杰斯特拉算法这篇博客 xff0c 能够让很多新同学和老同学通过直观的方式去理解算法求解的过程 xff0c 这样理解起来会比

随机推荐

  • linux opencv打开两个USB摄像头

    在ubuntu linux系统下 xff0c 摄像头设备是通过 dev videox来表示的 xff0c 如果只有一个摄像头 xff0c 则会在 dev目录下显示 video0和video1两个设备 xff0c 其中 xff0c video
  • 实现手机app和微信小程序远程控制加人体探测自动化控制51单片机打开流水灯(ESP8266 STC89C52RC http请求转串口通信系统)

    首先你有这样的8266 这种8266自身带2个按键和烧录芯片方便调试 xff0c 综合性价比较高 有一个51单片机 或者其他芯片都行 还有就是需要这种人体红外探测模块和led灯 有了这2个芯片我们开始吧 xff01 1 先看一段视频效果演示
  • 图像算法之图像平移

    在图像处理领域中 xff0c 图像变换是最基本的算法 xff0c 本文主要详细分享一下图像平移算法的原理和代码实现 xff0c 废话不多说 xff0c 直接上干货 1 图像平移的原理 在计算机图像中 xff0c 主要是用的是 像素直角坐标系
  • OpenCV之Mat的详细介绍

    在opencv中 xff0c Mat作为图像的存储容器 xff0c 是非常基础也是非常重要的知识 xff0c 本文主要介绍Mat相关的操作 1 图像复制 再开始将拷贝之前 xff0c 先给大家分享一下浅拷贝和深拷贝 浅拷贝 xff1a 拷贝
  • windows下Linaro-arm-linux编译开启NEON的Opencv源码详细过程

    环境配置 1 windows安装cmake 下载地址 xff1a https cmake org download 按照上图中的下载cmake的安装包 xff0c 安装注意事项如下 xff1a 安装路径切记不能包含空格 xff01 xff0
  • Windows 工具之net

    net 是windows平台下用户管理的工具 xff0c 可以来添加 xff0c 删除和修改用户 1 创建用户 xff1a win 43 R 输入cmd xff0c 然后打开命令行窗口 xff0c 输入下面的命令 xff1a net use
  • windows平台相关命令收集

    1 获取IP地址命令 xff1a ipconfig 2 获取MAC地址命令 xff1a ipconfig all 3 查看所有端口信息 netstat nal findstr 8080
  • C/C++中比较好用的HTTP开源库

    以下是一些常用的C C 43 43 开源HTTP库及其对应的开源协议和链接 xff1a 1 libcurl xff1a 使用MIT X开源协议 xff0c 支持多种协议和多种数据传输方式 xff0c 被广泛应用于各种开发场景 官网链接 xf
  • 为Ubuntu网页设置稳定的数据隧道

    网站作为互联网世界中的一个个门户 xff0c 是我们对外表达的窗口 xff0c 无数个人和企业通过这个窗口传递着信息 xff0c 这个传递信息的窗口必须稳定持续存在 xff0c 才能让更多访客看到 xff0c 为我们带来更多的流量 而使用c
  • VisualStudio配置与Matlab混合编译问题总结

    VisualStudio配置与Matlab混合编译问题总结 写这篇博客记录一下自己在配置过程中遇到的种种问题 xff0c 也做一个小小总结 xff0c 试图把整个过程讲明白 xff0c 希望对面临同样问题的人有所帮助 网上此类教程很多 xf
  • C++与C的区别(作业)

    头文件的区别 1 C 43 43 中创建源文件后缀为 cpp xff0c C语言中创建源文件后缀为 c xff0c 头文件保持不变 xff0c 后缀为 h 2 包含自己的头文件 xff0c C语言与C 43 43 无区别 包含库目录 xff
  • C++和C语言区别(二)附二级指针的动态内存申请

    结构体区别 1 定义结构体与C语言一致 2 定义变量可省略关键字struct 3 C 43 43 结构体中允许函数存在 xff08 C 43 43 在没有写构造函数和权限限定的时候 xff0c 用法和C语言一致 xff09 xff08 1
  • 自制芯片 http转串口通信模块实现手机控制加红外控制51单片机实现双控制 28BYJ-48步进电机( 13003步进电机驱动器 STC89C52RC ESP8266)

    首先你有这样的8266 这种8266自身带2个按键和烧录芯片方便调试 xff0c 综合性价比较高 还需要有一个51单片机 或者其他单片机都行 还有就是需要这样的13003步进电机驱动器 43 28BYJ 48步进电机和红外接收头以及遥控器
  • C++类和对象(附C语言与C++链表)

    类和对象的基本概念 1 类 xff1a 一系列事物的抽象 xff0c 万物皆可为类 xff08 1 xff09 属性 xff1a 事物的特征 数据类型的描述 xff08 2 xff09 行为 xff1a 事物的操作 函数描述 2 对象 xf
  • C++类的组合

    1 以另一个类的对象为数据成员 xff0c 必须采用初始化参数列表的写法 include lt iostream gt include lt string gt using namespace std class Boy public Bo
  • C++模板

    函数模板 1 把类型当作未知量 2 语法 template lt typename Ty gt Ty function Ty a Ty b return a gt b a b template lt class Ty1 class Ty2
  • C++STL容器(一)

    定长数组 include lt iostream gt include lt string gt include lt array gt using namespace std template lt class Ty size t siz
  • C++STL容器(二)

    链表 include lt iostream gt include lt string gt include lt list gt include lt functional gt 仿函数less和greater头文件 using name
  • C++正则表达式

    regex match regex replace regex search include lt iostream gt include lt regex gt include lt string gt using namespace s
  • C++时间管理和随机数

    时间段 include lt chrono gt duration TYPEDEFS typedef duration lt long long nano gt nanoseconds 纳秒 typedef duration lt long