1 毕业一年了,想起刚毕业那会所做的事 有点好笑。。。。
由于项目经理之前是用VB的,刚好要把项目的代码全转为C#,所以碰上了这个很好的机会,但工资低得可怜,抱着刚毕业主要是学习为主的心态,开始了我的职业生涯。
首先是从C#里最基本的模块做起,读取INI 读取XML,日志处理,数据库操作等等,这差不多做了一二个月吧,
其它这些基本的东西网上到处是,当时就没想过这么多,只是找过一些思路。真可谓 此情可待成追忆,只是当时已惘然。
如果从网上找这些对应的开源,不到一周就基本上能搞好了,真是浪费人力,浪费工资。
后面就把GIS里的模块用C#写了一遍,这对换工作是极有用的。
基本的数据管理,配置管理,视图操作,查询模块,分析,统计等模块。
日志处理并不是一个很简单的事情,当你有了Log4NET后就大可不必担心了,来看看如何快速的使用它吧。。
首先需要配置相关的配置文件App.config或Web.config,顾名思义普通应用的配置文件
为App.config,asp.net的配置文件为Web.config。有关log的配置如下:
<configuration>
<configSections>
<!-- log4net的定义 -->
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<!-- Console部分log输出格式的设定 -->
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />
</layout>
</appender>
<!-- 日志文件部分log输出格式的设定 -->
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="c:\a.log" />
<appendToFile value="true" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="1MB" />
<rollingStyle value="Size" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<header value="[Header] " />
<footer value="[Footer] " />
<ConversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
</layout>
</appender>
<!-- Setup the root category, add the appenders and set the default level -->
<root>
<level value="ALL" />
<appender-ref ref="ConsoleAppender" />
<appender-ref ref="RollingLogFileAppender" />
</root>
</log4net>
</configuration>
其次在项目的AssemblyInfo.cs里面加上[assembly: log4net.Config.XmlConfigurator()],这样项目工程和log4net就
建立了关联。
备注:[assembly: log4net.Config.DOMConfigurator()]这句话的意思是log4net系统会自动寻找配置文件App.config或Web.config
从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就要这样写:
[assembly:log4net.Config.DOMConfigurator(ConfigFile="filename",ConfigFileExtension="log4net",Watch=true)]
最后就是源文件中的使用了。
添加log4net的引用using log4net;
同时在相关的类中定义log变量如
protected static readonly log4net.ILog mLog =
LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log的具体操作,Form1中加入了:
如mLog.Error("ha ha log4NET");
找下你的C盘,里面的 c:\a.log吧
[Header] 2009-08-21 09:31:52,140 [10] ERROR Test.Form1 [(null)] - ha ha log4NET
怎么样?很方便吧,,之前写日志处理都 不知道花了多少时间,太爽了。。