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对象 ...
随机推荐
- Ubuntu 14.04 安装VMware 12
/*********************************************************************** * Ubuntu 14.04 安装VMware 12 ...
- js调用函数时括号加与不加的区别,function()&function
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- 上传到github!
今天课上在冯老师的带领下终于在github上成功上传了东西但是还有很多没用的东西,慢慢研究改进! https://github.com/Hxy94264/GitHubTest https://gith ...
- android 7.0变化
一.加强版的低电耗模式 条件:1未插电源:2屏幕关闭:(N与6.0的区别就在于N在手机非静止时也可进入低电耗模式) 作用过程及方式:1充电状态:2屏幕关闭一定时间:进入一级低电限制:关闭网络,推迟CP ...
- 硬件抽象层:HAL
本章主要讲硬件抽象层:HAL,它是建立在Linux驱动之上的一套程序库.刚开始介绍了为什么要在Android中加入HAL,目的有三个,一,统一硬件的调用接口.二,解决了GPL版权问题.三,针对一些特殊 ...
- linux的一些与关机和重启相关的命令
runlevel 查看系统级别 cat /etc/inittab 修改系统默认运行级别 logout 退出登录
- 第六篇T语言实例开发,多点找色应用
---恢复内容开始--- 多点找色应用 文字,图形特征的获取 多点找色 功能原型 窗口多点找色(窗口句柄,x1,y1,x2,y2,颜色值,色点组,相似度,方向,返回x,返回y) 功能说明 根据指定的多 ...
- API测试
API(Application Programming Interface)包含: 单元测试(Unit Testing).模块测试(Module Testing).组件测试(Component Tes ...
- android之Volley实现瀑布流
1.首先我们来看下主布局文件activity_main.xml. <RelativeLayout xmlns:android="http://schemas.android.com/a ...
- mysql配置命令 CHARACTER_SET_%字符集设置
参照: http://blog.csdn.net/mzlqh/article/details/7621307点击打开链接 其实现在的ubuntu12. 直接sudo apt-get install M ...