jjzjj

c++ - 这个预处理器指令在这里可以接受吗?

有一个单例Logger类,我觉得每次调用print方法时都编写Logger::GetInstance()很丑陋。我能想到的唯一解决方案是#define。有没有更好的方法,或者这个宏在这种情况下是否合理?#include#includeclassLogger{public:staticLogger&GetInstance();~Logger();templatevoidPrint(constT&t);voidSetNewline(boolb);voidSetLogging(boolb);private:Logger();Logger(constLogger&);voidoperator=

C++ 如何在 Boost Global Logger 上设置严重性过滤器

几天来我一直在尝试创建一个BoostGlobalLogger以在整个应用程序中使用但我似乎无法在GlobalLogger中设置严重性级别。重要提示:在下面查看Andrey的回答...它被标记为步骤(a)和(b),但我仍然没有做对!直接来自Boost文档here...itwouldbemoreconvenienttohaveoneorseveralgloballoggersinordertoeasilyaccessthemineveryplacewhenneeded.Inthisregardstd::coutisagoodexampleofsuchalogger.Thelibrarypr

C++ - 绕过 WinSock Hook

我想做的是使用theDetourslibrary连接到应用程序WinSock2send()和recv()函数(数据包记录器)。虽然它确实适用于send()函数,但它不适用于recv()函数。这是我的相关代码:#include#include#include#include#include#include#include#pragmacomment(lib,"Ws2_32.lib")#pragmacomment(lib,"detours.lib")#pragmacomment(lib,"detoured.lib")#pragmacomment(lib,"Mswsock.lib")std:

c++ - 监控 C++11 和 C++03 中的类实现?

HerbSutter在“C++andBeyond2012:HerbSutter-C++Concurrency”中描述了模板Monitor类的实现:templateclassmonitor{private:mutableTt;mutablestd::mutexm;public:monitor(Tt_):t(t_){}templateautooperator()(Ff)const->decltype(f(t)){std::lock_guardhold{m};returnf(t);}};我正在尝试包装我现有的类Logger:Loggerlogger;monitorsynchronizedLo

c++ - 如何在 C++ 中创建带有引用成员的数组?

我有一些类Foo和Logger:classLogger{/*somethinggoeshere*/};classFoo{Foo(Logger&logger);Logger&logger;}Foo::Foo(Logger&logger):logger(logger){}现在我想创建一个Foo类对象数组,其中所有引用Foo::logger都应该指向同一个Logger对象。我尝试了类似的方法(我需要堆栈和堆分配):Loggerlog(/*parameters*/);Fooobjects[3](log);//OnstackFoo*pObjects=newFoo[3](log);//Onheap

c++ - 如何重载不接受或不返回 ostream 的运算符 <<

原始问题我正在编写一个日志记录类,目标是能够做到这一点://threadoneLogger()目前我的Loggerheader看起来像这样:#pragmaonce;#includeclassLogger{public:Logger();~Logger();std::ostream*out_stream;};templateLogger&operator关于这个类的一些说明:跨平台兼容性不是问题。在Logger.cpp内部有一个单例类负责创建“真正的”ostream。Logger构造函数和析构函数执行必要的单例锁定。我有三个问题:如何让operator如何让operator如何添加特化,

c++ - Unresolved external symbol 错误仅发生在 64 位模式中,而不是在 32 位构建中

我有一个VC++代码(使用VS2008构建),它使用了一些静态库(*.lib文件在编译时静态链接)。为了便于理解,我们将我的EXE代码称为“AAA.EXE”并将lib文件称为“A.lib”、b.lib等...AAA.EXE代码和静态库代码都是使用VS2008构建的。我看到我的“AAA.EXE”在32位版本中运行良好,并且在以64位模式构建AAA.EXE时显示以下链接器错误。当然,我已经在64位模式下重建了静态库,并在我的AAA.EXE中提供了lib路径,如下所示:::“对应于AAA.EXE的项目配置属性->链接器->常规/输入”。这个链接器错误真的困扰了我很长时间。任何帮助是极大的赞赏

c++ - Poco Logging Framework 中记录器层次结构的问题

我在使用日志框架时遇到了一些问题。我有一个配置文件如下:#corechannellogging.channels.c1.class=FileChannellogging.channels.c1.path=/core.loglogging.channels.c1.archive=timestamplogging.channels.c1.times=utclogging.channels.c1.rotation=dailylogging.channels.c1.formatter.class=PatternFormatterlogging.channels.c1.formatter.pat

c++ - 如何编写具有 cout 样式接口(interface)的记录器类 (logger << "Error: "<< val << endl;)

我想创建一个具有如下功能的记录器类:Loggerlog;log这应该给我打印一条自定义格式的消息。例如。“12-09-200911:22:33看到错误5”我的简单类目前看起来像这样:classLogger{private:ostringstreamoss;public:templateLogger&operatorLogger&Logger::operator这将导致oss正确地拥有缓冲区“Error:5seen”。但我不知道我还需要编写/修改什么其他功能才能在屏幕上打印某些内容。有谁知道如何让它工作,或者是否有另一种方法来设计这个类来让我的功能正常工作?

c++ - Poco::Logger 线程安全吗?

在我下面的测试代码中似乎是线程安全的。我可以在多线程程序中使用Poco::Logger吗?staticPoco::Logger*pLogger;classMyRunnable:publicPoco::Runnable{private:std::string_name;Poco::Random_rnd;public:voidsetName(std::stringname){_name=name;}voidrun(){for(inti=0;iinformation("infofrom:"+_name);_rnd.seed(_rnd.next(65532)*_name.size());Poc