C++ write and read file via fstream and time cost
#include <iostream> #include <uuid/uuid.h> #include <ctime> #include <fstream> #include <sstream> #include <chrono> #include <string.h> using namespace std; void retrieveUuid1(char *uuidValue); char *getTimeNow(); void writeFile3(); void readFile4(); int main() { writeFile3(); return 0; } void readFile4() { fstream rFile("log.txt",ios::in); if(!rFile.is_open()) { cout<<"Open log.txt failed!"<<endl; } string line; unsigned num=0; while(getline(rFile,line)) { ++num; if(num%1000000==0) { cout<<"Num is "<<num<<",value is "<<line<<",now is "<<getTimeNow()<<endl; } } rFile.close(); cout<<"Now finished in openLog4() and now is "<<getTimeNow()<<endl; } void writeFile3() { fstream wFile("log.txt",ios::app|ios::out); if(!wFile.is_open()) { cout<<"Create or open log.txt failed!"<<endl; } unsigned num=0; stringstream ss; char *uuidValue=(char*)malloc(40); unsigned int loops=100; unsigned int loopTimes=1000000; string str; chrono::time_point<chrono::system_clock> startTime; chrono::time_point<chrono::system_clock> endTime; for(int i=0;i<loops;i++) { startTime=chrono::system_clock::now(); for(int j=0;j<loopTimes;j++) { ++num; retrieveUuid1(uuidValue); str=to_string(num); str.append(","); str.append(uuidValue); ss<<str<<endl; } wFile<<ss.str()<<endl; ss=stringstream(); endTime=chrono::system_clock::now(); cout<<"Num is "<<num<<",now is "<<getTimeNow()<<endl; cout<<"Time cost " <<chrono::duration_cast<chrono::seconds>(endTime-startTime).count()<<" seconds," <<chrono::duration_cast<chrono::milliseconds>(endTime-startTime).count()<<" milliseconds," <<chrono::duration_cast<chrono::microseconds>(endTime-startTime).count()<<" microseconds," <<chrono::duration_cast<chrono::nanoseconds>(endTime-startTime).count()<<" nanoseconds"<<endl<<endl; } free(uuidValue); wFile.close(); cout<<"Finished in log3() and now is "<<getTimeNow()<<endl; } void retrieveUuid1(char *uuidValue) { uuid_t newUUID; uuid_generate(newUUID); uuid_unparse(newUUID,uuidValue); } char *getTimeNow() { char *dtValue=(char*)malloc(20); time_t rawTime=time(NULL); struct tm tmInfo=*localtime(&rawTime); strftime(dtValue,20,"%Y%m%d%H%M%S",&tmInfo); return dtValue; }
Compile
g++ -g -std=c++2a -I. h1.cpp -o h1 -luuid
Run
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现