Ubuntu C++ uuid_generate vs Windows UuidCreate

1.Ubuntu,g++

复制代码
#include <chrono>
#include <iostream>
#include <uuid/uuid.h>

using namespace std;

void testTime(int x);

int main(int args,char**argv)
{
    testTime(atoi(argv[1]));
}

void testTime(int x)
{
    chrono::time_point<chrono::steady_clock> startTime;
    chrono::time_point<chrono::steady_clock> endTime;

    for(int i=0;i<x;i++)
    {
        startTime=chrono::steady_clock::now();   
        for(int j=0;j<1000000;j++)
        {
            uuid_t newUUID;
            uuid_generate(newUUID);
        }
        endTime=chrono::steady_clock::now();
        cout<<i<<","<<chrono::duration_cast<chrono::milliseconds>(endTime-startTime).count()<<" milliseconds!"<<endl;
    }
}
复制代码

Compile

g++ -std=c++2a *.cpp -o h1 -luuid

Run

./h1 10

Snapshot

 

 

2.Windows11/VS2022/VC++

复制代码
#pragma comment(lib, "rpcrt4.lib")
#include <iostream>
#include <chrono>
#include <fstream>
#include <iostream>
#include <sstream>
#include <string>
#include <Windows.h>

using namespace std;

int main()
{         
    for (int j = 0;j < 10;j++)
    {
        auto startTime = chrono::system_clock::now();
        for (int i = 0; i < 1000000; i++)
        {
            UUID uuid;
            UuidCreate(&uuid); 
        }
        auto endTime = chrono::system_clock::now();
        auto timeCost = chrono::duration_cast<chrono::milliseconds>(endTime - startTime).count();
        cout <<j<<"," << timeCost << " milliseconds" << endl;
    }
    cin.get();
}
复制代码

Release/X64,snapshot

 

posted @   FredGrit  阅读(121)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
历史上的今天:
2020-07-24 WPF Datagrid contains ComboBox while display textblock when display and combobox in editing mode
点击右上角即可分享
微信分享提示