log4cplus 直接创建logger 对象
#include <log4cplus/loggingmacros.h>
#include <log4cplus/fileappender.h>
#include <log4cplus/layout.h>
#include <log4cplus/consoleappender.h>
#include <log4cplus/logger.h>
#include <log4cplus/configurator.h>
using namespace log4cplus;
using namespace log4cplus::helpers;
void CreateLogConsole(const char *strLogName)
{
// 1、生成一个appender 对象
SharedAppenderPtr pConsoleAppender(new ConsoleAppender());
// 2、生成layout 对象并绑定到appender
std::auto_ptr<Layout> pLayout(new SimpleLayout());
pConsoleAppender->setLayout(pLayout);
// 3、生成logger 对象
Logger logSuyh = Logger::getInstance(LOG4CPLUS_TEXT(strLogName));
// 4、设置Logger 优先级
logSuyh.setLogLevel(ALL_LOG_LEVEL);
// 5、将需要关联的Logger 的Appender 添加到Logger 上
logSuyh.addAppender(pConsoleAppender);
// 6、使用Logger
LOG4CPLUS_ERROR(logSuyh, "Console self suyh.log");
LOG4CPLUS_ERROR_FMT(logSuyh, , "string text.");
}
void CreateLogFile(const char *strLogName, const char *strLogDir, const char *strLogFile)
{
// 1、生成一个appender 对象
MIFileAppender *miAppender = new MIFileAppender(LOG4CPLUS_TEXT(strLogDir));
miAppender->init(strLogFile, );
SharedAppenderPtr pAppender(miAppender);
// 2、生成layout 对象并绑定到appender
std::auto_ptr<Layout> pLayout(new SimpleLayout());
pAppender->setLayout(pLayout);
// 3、生成logger 对象
Logger logSuyh = Logger::getInstance(LOG4CPLUS_TEXT(strLogName));
// 4、设置Logger 优先级
logSuyh.setLogLevel(ALL_LOG_LEVEL);
// 5、将需要关联的Logger 的Appender 添加到Logger 上
// 这里可以添加多个appender ,这样只要用该strLogName 的Logger 对象输出的日志将会
// 同时输出到所有的appender 指定的文件或者控制台上
logSuyh.addAppender(pAppender);
// 6、使用Logger
LOG4CPLUS_ERROR(logSuyh, "Log file self suyh.log");
}
int main()
{
CreateLogFile("suyh_01", "suyh_log_dir", "log_file_01");
CreateLogFile("suyh_02", "suyh_log_dir", "log_file_02");
CreateLogFile("suyh_03", "suyh_log_dir", "log_file_03");
log4cplus::Logger logSuyh01 = log4cplus::Logger::getInstance("suyh_01");
log4cplus::Logger logSuyh02 = log4cplus::Logger::getInstance("suyh_02");
log4cplus::Logger logSuyh03 = log4cplus::Logger::getInstance("suyh_03");
LOG4CPLUS_INFO(logSuyh01, "log4cplus suyh01 log text...");
LOG4CPLUS_INFO(logSuyh02, "log4cplus suyh02 log text...");
LOG4CPLUS_INFO(logSuyh03, "log4cplus suyh03 log text...");
;
}
log4cplus 直接创建logger 对象的更多相关文章
- Spring AOP 源码分析 - 创建代理对象
1.简介 在上一篇文章中,我分析了 Spring 是如何为目标 bean 筛选合适的通知器的.现在通知器选好了,接下来就要通过代理的方式将通知器(Advisor)所持有的通知(Advice)织入到 b ...
- spring aop 源码分析(三) @Scope注解创建代理对象
一.源码环境的搭建: @Component @Scope(scopeName = ConfigurableBeanFactory.SCOPE_SINGLETON,proxyMode = ScopedP ...
- 死磕Spring之AOP篇 - Spring AOP自动代理(三)创建代理对象
该系列文章是本人在学习 Spring 的过程中总结下来的,里面涉及到相关源码,可能对读者不太友好,请结合我的源码注释 Spring 源码分析 GitHub 地址 进行阅读. Spring 版本:5.1 ...
- 创建javaScript对象的方法
一.工厂模式 function person (name,age) { var p=new Object(); p.name=name; p.age=age; p.showMessage=functi ...
- .net下灰度模式图像在创建Graphics时出现:无法从带有索引像素格式的图像创建graphics对象 问题的解决方案。
在.net下,如果你加载了一副8位的灰度图像,然后想向其中绘制一些线条.或者填充一些矩形.椭圆等,都需要通过Grahpics.FromImage创建Grahphics对象,而此时会出现:无法从带有索引 ...
- win7 装了VB虚拟机 开始挺好用 后来突然就打不开了 提示如下错误:(如图)创建 COM 对象失败.
创建 COM 对象失败. 应用程序将被中断. Start tag expected, '<' not found. Location: 'C:\Users\Mike/.VirtualBox\Vi ...
- 在这个看脸的世界,该如何优雅的创建JS对象
Javascript是一门解释型的语言,是基于对象的,严格来说并不怎么符合的面向对象的标准,显著的特点就是函数就是“一等对象”,与传统的面向对象语言不同的时,Javascript有“一千种”方法来创建 ...
- java 创建string对象机制 字符串缓冲池 字符串拼接机制
对于创建String对象的机制,在这一过程中涉及的东西还是值得探究一番的. 首先看通过new String对象和直接赋值的方式有什么区别,看如下代码: public static void main( ...
- 创建XMLHttpRequest对象
创建XMLHttpRequest对象 XMLHttpRequest对象: 用于在后台与服务器交换数据,可以在不重新加载整个页面的情况下,对页面的部分内容进行更新. 创建XMLHttpRequest对象 ...
随机推荐
- IOS设备 UIDevice 获取操作系统 版本 电量 临近手机触发消息检测 (真机亲测可用)
- (void)viewDidLoad { [super viewDidLoad]; // 操作系统 NSString * osName =[[UIDevice currentDevice]syste ...
- 蓝牙-HCI错误码列表
错误码定义: /* Success code */ #define HCI_SUCCESS 0x00 /* Possible error codes */ #define HCI_UNKNOWN_HC ...
- sublime上安装c/c++代码分析工具 sublime Linter - cppcheck
项目官方说明 sublime Linter - cppcheck 理解下sublime Linter - cppcheck, 它是插件的插件,sublime的插件sublimeLinter的插件.网络 ...
- c数据结构 顺序表和链表 相关操作
编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...
- 模仿console自写函数打印js的对象
本以为写个递归函数就可以将js的对象打印出来. 当然第一个想到的估计是JSON.stringify() 这个函数.但这个函数打印到浏览器 显示效果不友好.最友好的显示肯定是 控制台打印咯. 结果尝试打 ...
- java读取properties文件工具
public class PropertiesUtil { public static String get(String filePath, String key) { String val = n ...
- nginx 目录映射
---恢复内容开始--- 设置目录映射 ---恢复内容结束--- 设置目录映射
- 关于css3
1.选择器: 属性选择器:[]; 查找条件:属性:我们可以通过属性来查找[^=][$=][*=][=][attr] 伪类选择器: ::: ::before:::after: 必须指定一个conten ...
- LeetCode 【347. Top K Frequent Elements】
Given a non-empty array of integers, return the k most frequent elements. For example,Given [1,1,1,2 ...
- 【转】android 属性动画之 ObjectAnimator
原文网址:http://blog.csdn.net/feiduclear_up/article/details/39255083 前面一篇博客讲解了 android 简单动画之 animtion,这里 ...