一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>binary_log用于C++的快速二進制記錄器

binary_log用于C++的快速二進制記錄器

2022-06-16 | zip | 0.45 MB | 次下載 | 2積分

資料介紹

授權(quán)協(xié)議 MIT
開發(fā)語言 C/C++
軟件類型 開源軟件

軟件簡介

binary_log 是一個用于 C++ 的快速二進制記錄器。

Highlights

  • 以緊湊的二進制格式記錄消息
  • 快速地
    • 每秒數(shù)億條日志
    • 基本數(shù)據(jù)類型的平均延遲為2-7 ns
    • 查看基準
  • 提供解包器來壓縮日志消息
  • 使用?fmtlib?格式化日志
  • 同步日志記錄 - 不是線程安全的
  • Header-only library
    • 此處提供單個頭文件版本
  • 需要 C++20

Usage and Performance

以下代碼將 10 億個整數(shù)記錄到文件中。

#include <binary_log/binary_log.hpp>

int main()
{
  binary_log::binary_log log("log.out");

  for (int i = 0; i < 1E9; ++i)
    BINARY_LOG(log, "Hello logger, msg number: {}", i);
}

在一個現(xiàn)代工作站桌面上,上述代碼的執(zhí)行時間為~3.5秒。

Type Value
Time Taken 3.5 s
Throughput 1.4 Gb/s
Performance 286 million logs/s
Average Latency 3.5 ns
File Size ~5 GB
foo@bar:~/dev/binary_log$ time ./build/examples/billion_integers/billion_integers

real    0m3.561s
user    0m2.422s
sys     0m1.141s

foo@bar:~/dev/binary_log$ ls -lart log.out*
-rw-r--r-- 1 pranav pranav          6 Dec  6 07:52 log.out.runlength
-rw-r--r-- 1 pranav pranav         32 Dec  6 07:52 log.out.index
-rw-r--r-- 1 pranav pranav 4999934337 Dec  6 07:52 log.out

設(shè)計目標(biāo)和決策

  • 實現(xiàn)單線程同步記錄器 - 不提供線程安全
    • 如果用戶想要多線程行為,用戶可以選擇并實現(xiàn)自己的排隊解決方案
    • 有許多眾所周知的無鎖隊列可用于此目的(moody::concurrentqueue、atomic_queue等)——讓用戶選擇他們想要使用的技術(shù)。
    • 進入無鎖隊列的延遲足夠大
      • 不關(guān)心多線程場景的用戶不應(yīng)該為此付出代價
      • 查看atomic_queue benchmarks,在許多最先進的多生產(chǎn)者、多消費者隊列中發(fā)送和接收 4 字節(jié)整數(shù)(在 2 個線程之間,使用 2 個隊列)的平均往返延遲約為150-250 納秒。
  • 避免多次寫入靜態(tài)信息
    • 靜態(tài)信息示例:格式字符串、格式參數(shù)的數(shù)量以及每個格式參數(shù)的類型
    • 將靜態(tài)信息存儲在“索引”文件中
    • 將動態(tài)信息存儲在日志文件中(盡可能參考索引文件)
  • 在運行時 hot path?中做盡可能少的工作
    • 沒有任何形式的格式
    • 所有格式化都將使用解壓縮二進制日志的解包器脫機進行

運作方式

binary_log?將日志拆分為三個文件:

poYBAGKoB-iAGCmwAAMO3JWjGCw169.png

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DD3118電路圖紙資料
  2. 0.08 MB   |  1次下載  |  免費
  3. 2AD庫封裝庫安裝教程
  4. 0.49 MB   |  1次下載  |  免費
  5. 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
  6. 1.12 MB   |  1次下載  |  免費
  7. 4網(wǎng)絡(luò)安全從業(yè)者入門指南
  8. 2.91 MB   |  1次下載  |  免費
  9. 5DS-CS3A P00-CN-V3
  10. 618.05 KB  |  1次下載  |  免費
  11. 6海川SM5701規(guī)格書
  12. 1.48 MB  |  次下載  |  免費
  13. 7H20PR5電磁爐IGBT功率管規(guī)格書
  14. 1.68 MB   |  次下載  |  1 積分
  15. 8IP防護等級說明
  16. 0.08 MB   |  次下載  |  免費

本月

  1. 1貼片三極管上的印字與真實名稱的對照表詳細說明
  2. 0.50 MB   |  103次下載  |  1 積分
  3. 2涂鴉各WiFi模塊原理圖加PCB封裝
  4. 11.75 MB   |  89次下載  |  1 積分
  5. 3錦銳科技CA51F2 SDK開發(fā)包
  6. 24.06 MB   |  43次下載  |  1 積分
  7. 4錦銳CA51F005 SDK開發(fā)包
  8. 19.47 MB   |  19次下載  |  1 積分
  9. 5PCB的EMC設(shè)計指南
  10. 2.47 MB   |  16次下載  |  1 積分
  11. 6HC05藍牙原理圖加PCB
  12. 15.76 MB   |  13次下載  |  1 積分
  13. 7802.11_Wireless_Networks
  14. 4.17 MB   |  12次下載  |  免費
  15. 8蘋果iphone 11電路原理圖
  16. 4.98 MB   |  6次下載  |  2 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191390次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183342次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81588次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73815次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65989次下載  |  10 積分