- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
代码片段:
void CMyLogger::Log(
LogLevel level, LPCTSTR file, INT line, LPCTSTR func, LPCTSTR format, ...)
{
time_t tCurrentLogTime;
time(&tCurrentLogTime);
tm tmCurrentLogTime;
localtime_s(&tmCurrentLogTime, &tCurrentLogTime);
// Check the date is changed
if (m_tmCurrentLogTime.tm_year == tmCurrentLogTime.tm_year
&& m_tmCurrentLogTime.tm_mon == tmCurrentLogTime.tm_mon
&& m_tmCurrentLogTime.tm_mday == tmCurrentLogTime.tm_mday)
{
// Check the log file size has exceeded the maximum size
struct _stat st;
_tstat(m_szCurrentLogFile, &st);
if (st.st_size > m_nMaxLogSize)
{
m_nCurrentLogIndex++;
GetCurrentLogFile();
CLogger::ClearOutputStreams();
// Add logger
AddOutputStream(new std::tofstream(m_szCurrentLogFile), true, LogLevel::Info);
}
}
// The date is changed
else
{
// Get current log time
memcpy(&m_tmCurrentLogTime, &tmCurrentLogTime, sizeof(tmCurrentLogTime));
m_nCurrentLogIndex = 0;
DeleteOldFiles();
GetCurrentLogFile();
CLogger::ClearOutputStreams();
// Add logger
AddOutputStream(new std::tofstream(m_szCurrentLogFile), true, LogLevel::Info);
}
// Log
va_list args;
va_start(args, format);
int length = _vsctprintf(format, args ) + 1;
TCHAR* text = new TCHAR[length];
_vstprintf_s(text, length, format, args);
va_end(args);
CLogger::Log(level, file, line, func, text);
delete [] text;
}
以上是日志程序的代码片段。如果日志文件超过 1 MB,则创建新的日志文件。 (xxx_000.log => xxx_001.log ...) 我写了下面的代码来测试当日志文件超过 1 MB 时是否创建新的日志文件:
#ifdef UNICODE
#define LOG(level, format, ...) CEagleLogger::GetInstance()->Log(level, __FILEW__, __LINE__, __FUNCTIONW__, format, __VA_ARGS__);
#else
#define LOG(level, format, ...) CEagleLogger::GetInstance()->Log(level, __FILE__, __LINE__, __FUNCTION__, format, __VA_ARGS__);
#endif
// ...
while (1)
LOG(LogLevel::Info, _T("================================================================================"));
但是,日志文件并不是每 1 MB 创建一次。日志文件大小在写入日志之前通过 stat
函数进行检查。当实际日志文件大小超过 1 MB 时,“统计”功能不会超过 1 MB。 “stat”功能更新慢?
最佳答案
stat
是一个 POSIX 函数。 _tstat
是一个 Windows 函数,旨在帮助将 POSIX 代码移植到 Windows(但 _t 东西阻碍了以其他方式移植)。不要期望此类包装器具有最佳性能。
特别是,stat
等同于 Windows 上的 FindFirstFile
,Visual Studio 中包含的 CRT 代码证实了这一点:_stat< 中的第一个系统调用
是 FindFirstFileEx(FindExInfoStandard ... FindExSearchNameMatch)
。 .它为您提供目录条目的许多属性,包括目录中的文件大小。对于正在写入的文件,该信息已过时。 GetFileSize
has the correct size
(请注意,_stat
也做了相当多的工作来获取您甚至不想要的各种属性。这在 UNIX 上非常便宜,但在 Windows 上文件访问权限必须模拟东西。也不快。)
关于c++ - "stat"函数更新慢?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31529450/
所以,我正在尝试创建一种 ls 函数。这是我对每个文件的描述的代码 struct stat fileStat; struct dirent **files; num_entries = scandir
我最近一直在尝试实现我自己的 linux ls 命令版本。一切都很好,但是当我尝试使用 ls -l 功能时,struct stat 的某些字段未初始化 - 我得到 NULL 指针或垃圾值,尽管它似乎只
我在 Yii 中遇到 STAT 关系问题。我不确定我正在寻找的东西是否可以通过本地 Yii 关系实现。我会尽力描述我的问题,如果不清楚,请询问任何具体细节。 我有三个表,因此有三个模型 | table
我正在为一个严重依赖 scipy.stats.stats(scipy 版本 0.9.0)的包创建一个 django-powered (1.3) 接口(interface),称为 ovl 。在早期开发阶
为了安全起见,我喜欢显式初始化我的变量(当您编写大量代码时,它通常会使它更安全,因为您的代码最终不会崩溃那么多。) 对于大多数类型,无论是结构还是整数等基本 C++ 类型,我都可以编写以下内容: ti
我一直在使用 stat() 检查文件是否存在,据我所知,这比尝试打开文件更好。但是,stat() 不适用于包含其他语言的 unicode 字符的文件名。是否有 stat() 的宽字符版本或我可以使用的
错误: File "/usr/lib/python2.7/dist-packages/statsmodels/regression/linear_model.py", line 36, in
下面是我要运行的脚本。我不能在 awk 中使用 stat。 cat /etc/passwd | awk 'BEGIN{FS=":"}{print $6 }' | (stat $6 | sed -n '
我正在尝试拟合 xlog 线性回归。我使用 Seaborn regplot 来绘制拟合,看起来很合适(绿线)。然后,因为 regplot 不提供系数。我使用 stats.linregress 来查找系
我正在尝试使用共享库 (libscplugin.so) 中包含的方法。 我已经满足了库的所有要求: libc.so 带有指向 libc.so.6 的符号链接(symbolic link) libz.s
嘿,感谢阅读。 我正在制作一个程序,它接受 1 个参数(目录)并使用 opendir()/readdir() 读取目录中的所有文件,并使用 stat 显示文件类型(reg、链接、目录等)。当我在 sh
简单问题:在 Linux 中,我 stat() 一个不是设备的文件。 st_rdev 字段的期望值是多少?我可以运行 major(stat.st_rdev) 和 minor(stat.st_rdev)
我正在尝试为我的 Angular 6 应用程序生成 stats.json 文件。下面的事情我已经尝试过,但根本没有生成文件。我的系统需要有 “npm 运行”在每个 angular cli 命令之前。
我正在尝试使用返回的 stat 结构中的 st_mode,该结构是我通过以下方式从 stat() 调用获得的; char *fn = "test.c" struct s
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我有一个程序,是我通过修改原始暗网(深度学习图像识别,Yolov2)的许多地方而制作的。几个月前我一直在使用它,但是今天当我编译它时,它给了我一个错误: gcc -DSAVE_LAYER_INPUT
我预计 scipy.stats.mstats.pearsonr 对于屏蔽数组输入的结果将与 scipy.stats.pearsonr 对于输入数据的 unmasked 值给出相同的结果,但它不会't:
给定 tmp.c: #include #include #include int main(int argc, const char *argv[]) { struct stat st;
In [15]: a = np.array([0.5, 0.5, 0, 0, 0]) In [16]: b = np.array([1, 0, 0, 0, 0]) In [17]: entropy(a
当我们运行 stat filename我们得到 Access: 2021-06-25 15:40:18.532621916 +0530 Modify: 2020-08-13 15:57:30.0000
我是一名优秀的程序员,十分优秀!