草庐IT

binary-log

全部标签

c++ - 如何让 boost::iostream 以类似于 std::ios::binary 的模式运行?

我有以下关于boost::iostreams的问题。如果有人熟悉编写过滤器,我将非常感谢您的建议/帮助。我正在编写一对多字符过滤器,它们与boost::iostream::filtering_stream一起用作数据压缩器和解压缩器。我从编写压缩器开始,从lz系列中学习了一些算法,现在正在研究解压缩器。简而言之,我的压缩器将数据拆分为数据包,这些数据包分别编码,然后刷新到我的文件中。当我必须从我的文件中恢复数据时(在编程术语中,接收一个read(byte_count)请求),我必须读取一个完整打包block,缓冲它,解压它,然后才给出请求的字节数。我已经实现了这个逻辑,但现在我正在努力

c++ - C : x86 Intel Intrinsics usage of _mm_log2_ps() -> error: incompatible type 'int' ?

我正在尝试将log2应用于__m128变量。像这样:#includeintmain(void){__m128two_v={2.0,2.0,2.0,2.0};__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)return0;}尝试编译会返回此错误:error:initializing'__m128'withanexpressionofincompatibletype'int'__m128log2_v=_mm_log2_ps(two_v);//log_2:=log(2)^~~~~~~~~~~~~~~~~~~我该如何解决?

c# - 我可以将 C DLL 的输出重定向到我的 c# log4net 输出吗

我有一个C#应用程序,它依次加载C或C++dll(依次加载其他C/C++dll)。在C#应用程序中,我使用log4net记录器将所有输出捕获到一系列日志文件中。我的应用程序作为Windows服务运行,因此没有用于正常printfs或写入stdout/stderr的输出的控制台/输出窗口。有没有一种方法可以设置C#应用程序以引导stdout/stderr(来自DLL)并将每一行转换为log4net输出。或者在C/C++DLL中是否有某种方式将stdout/stderr流连接到log4net输出?我找到了一些解决方案(此处:http://bytes.com/topic/c-sharp/an

c++ - 使用 log4cxx 进行日志记录和过滤

我正在开发需要日志记录和过滤功能的应用程序。我正在使用C++。我开始了解log4cxx支持日志记录。我在过滤时遇到困难。我有五个字段MACID日期和时间命令类型状态短信我需要将这5个字段存储在日志文件中,并根据以下过滤选项对其进行过滤。日志记录和过滤将在运行时自行完成。一旦文件大小达到10MiB,它将从头开始重写文件。过滤选项1.MACID2.日期和时间过滤可以通过过滤其中一个或两个来完成。结果应返回日志文件中的所有字段。是否可以使用log4CXX在日志文件中存储多个字段?如何根据上述条件过滤信息?我是否需要编写自己的过滤器类并继承现有的过滤器类?我是否需要编写自定义记录器类来在日志文

c++ - inplace_merge : What causes a complexity of N*log(N) vs. N-1?

根据关于inplace_merge的C++文档,该算法的复杂度是“如果使用内部缓冲区,则比较线性(N-1),否则为NlogN(其中N是范围[first,last)中的数字元素)”.它们所说的内部缓冲区是什么意思,是什么导致了O(N-1)与O(NlogN)的复杂性? 最佳答案 扩展其他答案:至少在libstdc++和libc++中,“内部缓冲区”是通过调用std::get_temporary_buffer提供的,STL中一个晦涩但标准的例程。此例程已在C++17中弃用,主要是因为它令人困惑且有点愚蠢。参见thisquestion有关详

c++ - boost 序列化 binary_oarchive 崩溃

首先,我填充了一个相当大且相互关联的结构。然后我将其序列化为二进制存档。该结构的大小取决于我提供给程序的数据。我看到该程序使用~2GB内存来构建预期和可接受的结构。然后我开始序列化对象。我看到程序在序列化时占用RAM。RAM使用率不断增长,直到接近100%。交换使用仍然是0字节。然后应用程序崩溃。new上的bad_alloc除外为什么序列化过程会占用如此多的RAM和时间?为什么在交换为空时分配内存时会崩溃?回溯太长,无法完整粘贴。#00xb7fe1424in__kernel_vsyscall()#10xb7c6e941inraise(sig=6)at../nptl/sysdeps/un

c++ - 使用 Boost.Log 构建 Boost "error: target { simple_event_log.mc. } has no type"

我正在尝试构建Boost.Log(http://boost-log.sourceforge.net/libs/log/doc/html/index.html)。我将它添加到我的boost源并执行了我常用的boost构建命令。b2--build-dir="D:\boost\1.51.0\boost"toolset=gccvariant=releaselink=staticthreading=multiruntime-link=static--build-type=complete但什么也没发生,最后我收到了这个:D:/boost/1.51.0/src/tools/build/v2/bui

c++ - 'long long long' 对于使用 log4cpp 的 GCC 来说太长了

我正在开发一个使用日志库log4cpp的QT应用程序。但是现在,在包含log4pp的头文件的地方,我得到了这个编译错误:'longlonglong'对于GCC来说太长了当我找到这个错误的根源时,头文件stdint.h在这一行打开:__MINGW_EXTENSIONtypedeflonglongint64_t;有人能告诉我如何处理吗? 最佳答案 好的,解决了,我只需要在开始时包含stdint.h 关于c++-'longlonglong'对于使用log4cpp的GCC来说太长了,我们在Sta

c++ - 在 boost::log 中使用格式语法

在boost::log进入官方boost库之前(从1.54开始),我使用的是sourceforgeversion使用以下代码:boost::log::formatters::fmt_formatsimpleFormat(boost::log::formatters::format("%1%%2%")%boost::log::formatters::date_time("TimeStamp",boost::log::keywords::format="%H:%M:%S")%boost::log::formatters::message());以及后来的:log_sink->locked_

Android笔记(二) 常见log

用户按键操作,唤醒屏幕S00B134 04-1902:46:37.926  951 1128DWindowManager:ReceiveInputKeyEventofPowerkeydownS00B138 04-1902:46:37.929  951 1128DWindowManager:wakeUpFromPowerKeyS00B139 04-1902:46:37.929  951 1128IPowerManagerService:WakingupfromAsleep(uid=1000,reason=WAKE_REASON_POWER_BUTTON,details=android.polic