mirror of http://192.168.1.51:8099/lmh188/twain3.0
增加工具类
This commit is contained in:
parent
8517b68619
commit
644dd609fd
|
@ -0,0 +1,34 @@
|
||||||
|
#pragma once
|
||||||
|
#include <chrono>
|
||||||
|
|
||||||
|
class StopWatch
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
StopWatch() {
|
||||||
|
_start = std::chrono::steady_clock::now();
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset() {
|
||||||
|
_start = std::chrono::steady_clock::now();
|
||||||
|
}
|
||||||
|
|
||||||
|
double elapsed_s() {
|
||||||
|
return std::chrono::duration<double>(std::chrono::steady_clock::now() - _start).count();
|
||||||
|
}
|
||||||
|
|
||||||
|
double elapsed_ms() {
|
||||||
|
return std::chrono::duration<double, std::milli>(std::chrono::steady_clock::now() - _start).count();
|
||||||
|
}
|
||||||
|
|
||||||
|
double elapsed_us() {
|
||||||
|
return std::chrono::duration<double, std::micro>(std::chrono::steady_clock::now() - _start).count();
|
||||||
|
}
|
||||||
|
|
||||||
|
double elapsed_ns() {
|
||||||
|
return std::chrono::duration<double, std::nano>(std::chrono::steady_clock::now() - _start).count();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::chrono::steady_clock::time_point _start;
|
||||||
|
};
|
||||||
|
|
|
@ -0,0 +1,65 @@
|
||||||
|
#pragma once
|
||||||
|
#include <vector>
|
||||||
|
#ifdef WIN32
|
||||||
|
#include <io.h>
|
||||||
|
#endif
|
||||||
|
#include <fstream>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
class FileTools
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
|
||||||
|
static std::vector<std::string> getFiles(std::string path)
|
||||||
|
{
|
||||||
|
std::vector<std::string> files;
|
||||||
|
getFiles(path, files);
|
||||||
|
return files;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void write_log(std::string filename, std::string log)
|
||||||
|
{
|
||||||
|
std::string savepath;
|
||||||
|
std::string str = "D:";
|
||||||
|
savepath = str+"\\"+filename;
|
||||||
|
std::ofstream ofs(savepath, std::ios::app);
|
||||||
|
|
||||||
|
time_t timp;
|
||||||
|
struct tm* p;
|
||||||
|
time(&timp);
|
||||||
|
p=localtime(&timp);
|
||||||
|
ofs << p->tm_year+1900 << "/" << p->tm_mon+1 << "/" << p->tm_mday << " " << p->tm_hour << ":" << p->tm_min << ":" << p->tm_sec << " "<<log << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
static void getFiles(std::string path, std::vector<std::string>& files)
|
||||||
|
{
|
||||||
|
#ifdef WIN32
|
||||||
|
//文件句柄
|
||||||
|
long hFile = 0;
|
||||||
|
//文件信息
|
||||||
|
struct _finddata_t fileinfo;
|
||||||
|
std::string p;
|
||||||
|
if ((hFile = _findfirst(p.assign(path).append("\\*").c_str(), &fileinfo))!=-1)
|
||||||
|
{
|
||||||
|
do
|
||||||
|
{
|
||||||
|
//如果是目录,迭代之
|
||||||
|
//如果不是,加入列表
|
||||||
|
if ((fileinfo.attrib & _A_SUBDIR))
|
||||||
|
{
|
||||||
|
if (strcmp(fileinfo.name, ".") != 0 && strcmp(fileinfo.name, "..") != 0)
|
||||||
|
getFiles(p.assign(path).append("\\").append(fileinfo.name), files);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
files.push_back(p.assign(path).append("\\").append(fileinfo.name));
|
||||||
|
}
|
||||||
|
} while (_findnext(hFile, &fileinfo) == 0);
|
||||||
|
_findclose(hFile);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
Loading…
Reference in New Issue