【C/C++】chrono簡單使用場景

chrono使用場景舉例

1 輸出格式化字符串

示例代碼

auto now = std::chrono::system_clock::now();
auto t = std::chrono::system_clock::to_time_t(now);
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;std::ostringstream oss;
oss << std::put_time(std::localtime(&t), "%F %T")<< "." << std::setw(3) << std::setfill('0') << ms.count();

這段代碼使用C++11的<chrono>庫獲取當前時間并生成帶毫秒的時間戳字符串。

  1. 獲取當前時間點
auto now = std::chrono::system_clock::now();
  • system_clock::now(): 獲取當前系統時間點(UTC時間)
  • 返回類型:std::chrono::system_clock::time_point

  1. 轉換為C風格時間
auto t = std::chrono::system_clock::to_time_t(now);
  • to_time_t(): 將time_point轉換為time_t(自1970-01-01起經過的秒數)
  • 用于后續調用傳統C時間函數

  1. 提取毫秒部分
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(now.time_since_epoch()) % 1000;
  • time_since_epoch(): 獲取從時鐘紀元到now的時間間隔
  • duration_cast<milliseconds>: 將時間間隔轉換為毫秒精度
  • % 1000: 取模運算獲取當前秒內的毫秒數(0-999)

  1. 格式化輸出
oss << std::put_time(std::localtime(&t), "%F %T") << "." << std::setw(3) << std::setfill('0') << ms.count();
  • localtime(&t): 將time_t轉換為本地時間的tm結構
  • put_time(..., "%F %T"): 格式化為YYYY-MM-DD HH:MM:SS
    • %F 等價于 %Y-%m-%d
    • %T 等價于 %H:%M:%S
  • ms.count(): 獲取毫秒數值(整數)
  • setw(3) + setfill('0'): 確保毫秒固定3位(如5→"005")

最終輸出格式
YYYY-MM-DD HH:MM:SS.sss
示例:2023-10-05 14:30:45.123


注意事項

  1. 線程安全性
    std::localtime不是線程安全的(使用靜態緩沖區)。多線程環境下應改用:

    std::tm tm_buf;
    localtime_r(&t, &tm_buf);  // POSIX
    // 或
    localtime_s(&tm_buf, &t);  // Windows
    
  2. C++20替代方案
    C++20的<chrono>庫提供更簡潔的時間格式化:

    auto now = std::chrono::system_clock::now();
    return std::format("{:%Y-%m-%d %H:%M:%S}", now);
    
  3. 精度控制
    當前代碼精確到毫秒,如需微秒/納秒:

    // 微秒示例
    auto us = std::chrono::duration_cast<std::chrono::microseconds>(now.time_since_epoch()) % 1000000;
    

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/85585.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/85585.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/85585.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Med-R1論文閱讀理解-1

論文總結&#xff1a;Med-R1: Reinforcement Learning for Generalizable Medical Reasoning in Vision-Language Models 論文寫了什么&#xff1f; 本文提出了一種名為 Med-R1 的新框架&#xff0c;旨在通過強化學習&#xff08;Reinforcement Learning, RL&#xff09;提升…

京東熱點緩存探測系統JDhotkey架構剖析

熱點探測使用場景 MySQL 中被頻繁訪問的數據 &#xff0c;如熱門商品的主鍵 IdRedis 緩存中被密集訪問的 Key&#xff0c;如熱門商品的詳情需要 get goods$Id惡意攻擊或機器人爬蟲的請求信息&#xff0c;如特定標識的 userId、機器 IP頻繁被訪問的接口地址&#xff0c;如獲取用…

MCU_IO驅動LED

注意事項&#xff1a; 1、亮度要求較高的情況下&#xff0c;不能由IO直接驅動LED MCU_IO引腳輸出的電壓和電流較弱&#xff0c;如果對光的亮度有要求的話&#xff0c;需要使用三極管來驅動。 MCU_IO的電壓一般為3.3V或者5V&#xff0c;輸出電流一般10mA-25mA。 2、不同顏色…

MyBatis 深度解析:高效 Java 持久層框架實踐指南(基于 3.5.10)

一、MyBatis 核心架構與設計哲學 MyBatis 作為半自動 ORM 框架&#xff0c;核心設計目標是在靈活性與開發效率之間取得平衡。與 Hibernate 等全自動 ORM 框架不同&#xff0c;MyBatis 允許開發者完全控制 SQL 編寫&#xff0c;同時通過映射機制減少重復代碼&#xff0c;特別適…

二叉樹(二)

98.驗證二叉樹 中序遍歷二叉樹&#xff0c;每次遍歷存下當前節點的值&#xff0c;遍歷到下一個節點比較&#xff0c;根據二叉搜索樹的特性&#xff0c;左<中<右有&#xff1a; 如果當前值小于或等于上一個的值&#xff0c;說明不是二叉搜索樹 如果當前值大于上一個節點…

解決Vue3+uni-app導航欄高亮自動同步方案

路由跳轉自動識別導航高亮實現方法 以下代碼使用wd-tabbar組件實現路由跳轉時自動同步導航欄高亮狀態&#xff0c;適用于所有的Vue3uni-app項目。 請根據自身使用框架類型完成&#xff0c;也可根據我使用的UI組件進行完成地址如下&#xff1a; Tabbar 標簽欄 | Wot UI &#…

免費論文查重與AI檢測工具推薦

文章目錄 概要一、PaperPass二、PaperYY注意 概要 畢業季&#xff0c;總少不了查重這一步&#xff0c;甚至查 AI 率。推薦兩款免費查重AIGC檢測的工具。 論文免費查重查AI&#xff1a; https://paperpass.com/ https://www.paperyy.com/ 一、PaperPass 網址&#xff1a; ht…

4、ubuntu系統 | 文本和目錄操作函數

1、目錄操作函數 ls(列出目錄內容) 用途:列出指定目錄中的文件和子目錄。語法:ls [選項] [路徑]常用選項: -l:以長格式顯示文件詳細信息(權限、所有者、大小、時間等)。-a:顯示隱藏文件(以.開頭的文件)。-R:遞歸列出子目錄內容。# 列出當前目錄下的所有文件和子目…

C++--范圍for循環詳解

范圍 for 循環是 C11 引入的語法特性&#xff0c;用于簡化遍歷容器或數組元素的過程。它比傳統 for 循環更簡潔安全&#xff0c;特別適合初學者。以下是詳細講解&#xff1a; 基本語法 for (元素類型 變量名 : 容器/數組) {// 循環體&#xff08;使用變量名訪問當前元素&#…

RDMA簡介1之RDMA開發必要性

為了滿足大批量數據的采集、存儲與傳輸需求&#xff0c;越來越多的數據密集型應用如機器學習、雷達、金融風控、航空航天等選擇使用現場可編程邏輯門陣列作為數據采集前端硬件來實現高性能的數據采集系統。FPGA憑借其高靈活性、高并行能力及可高度定制化的特點&#xff0c;能夠…

xmake的簡易學習

文章目錄 1. xmake是什么2. 一個可執行程序3. 一個庫文件4. 遍歷文件用法5. 第三方庫3.1 系統安裝庫3.2 獨立庫 6. 后續 由于前一篇博客的最后說要做一些rknn的優化&#xff0c;其實這個工作很早就完成了&#xff0c;但是我是使用 xmake這個來做我的工程的構建的&#xff0c;不…

【ArcGIS微課1000例】0147:Geographic Imager6.2下載安裝教程

文章目錄 一、軟件功能二、下載地址三、安裝教程Geographic Imager地圖工具使Adobe Photoshop空間圖像可以快速高效地工作。它增加了導入,編輯,操作和導出地理空間圖像的工具,例如航空和衛星圖像。Geographic Imager Mac功能非常強大,擁有柵格數據輸出、投影信息修改、基于…

【 java 集合知識 第一篇 】

1.概念 1.1.集合與數組的區別 集合&#xff1a;長度不固定&#xff0c;動態的根據數據添加刪除改變長度&#xff0c;并且只能存入引用類型&#xff0c;讀取采用迭代器或其他方法 數組&#xff1a;長度固定&#xff0c;不可改變&#xff0c;既可以存入基本類型也可以存入引用…

嵌入式開發學習日志(linux系統編程--系統編程之 進程間通信IPC)Day32

一、引言 空間獨立&#xff0c;需要一些操作&#xff1b; 分為三大類&#xff1a; 1、古老的通信方式 無名管道 有名管道 信號 2、IPC對象通信 system v BSD suse fedora kernel.org 消息隊列(用的相對少&#xff0c;這里不討論) …

metersphere不同域名的參數在鏈路測試中如何傳遞?

域名1&#xff1a;https://api.domain1.com 域名2&#xff1a;https://api.domain2.com 域名1的返回參數stteid會作為域名2的入參 步驟&#xff1a; 1&#xff09;先在metersphere—接口測試—接口定義中創建域名1和域名2的接口 2&#xff09;接口創建好后&#xff0c;在接口測…

使用Process Explorer、System Informer(Process Hacker)和Windbg工具排查軟件高CPU占用問題

目錄 1、問題現象 2、使用Process Explorer和System Informer&#xff08;該工具原先叫Process Hacker&#xff09;查看占用CPU高的線程 3、使用System Informer工具時發現了一個關鍵細節 4、將Windbg附加到軟件進程上&#xff0c;根據System Informer中顯示的線程id到Wind…

Linux(線程概念)

目錄 一 虛擬地址到物理地址的轉換 1. 操作系統如何管理物理內存&#xff1a; 2. 下面來談談虛擬地址如何轉換到物理地址&#xff1a; 3. 補充字段&#xff1a; 二 Linux中的線程 1. 先來說說進程&#xff1a; 2. 線程&#xff1a; 3. 線程相比較于進程的優缺點&#x…

阿里云為何,一個郵箱綁定了兩個賬號

阿里云“幽靈賬號”之謎&#xff1a;同一個郵箱注銷后仍有兩個賬號&#xff1f;深度揭秘成因與終極解決方案&#xff01; 你是否曾在阿里云上使用同一個郵箱注冊過多個賬號&#xff0c;明明已經**“徹底”注銷了其中一個**&#xff0c;卻驚愕地發現系統里依然**“幽靈般”掛著…

動態規劃-數位DP

今天開始做關于數位DP的問題&#xff0c;首先對于數位DP來說&#xff0c;這類問題難度較大&#xff0c;比較難理解&#xff0c;所以博主也會盡量講的更加詳細一些&#xff0c;來幫助大家更好地理解這里的相關知識。 前置知識&#xff1a; 1.首先對于數位DP來說&#xff0c;主…

總覽四級考試

別被“四級”這個龐然大物嚇到&#xff01;我們一起拆解它&#xff1a;?? &#x1f4cd; ??核心認知&#xff1a;四級是一場策略性考試&#xff01;?? 它不考智商&#xff0c;考的是??基礎英語能力 考試技巧 時間管理??。基礎可以通過努力補&#xff0c;技巧可以…