log4net的配置与使用(3)

 一个调用log4net和LoggingService 的示例:

using  ISharpDevelop.Core;

using  System;
using  System.Diagnostics;
using  System.IO;
using  System.Reflection;
using  System.Windows.Forms;

using  ICSharpCode.Core;


namespace  LoggerTest
{
    
public class Main
    
{
        
static string[] commandLineArgs = null;

        
public static string[] CommandLineArgs
        
{
            
get
            
{
                
return commandLineArgs;
            }

        }


        
public static void Main(string[] args)
        
{
#if DEBUG
            
if (Debugger.IsAttached)
            
{
                Run(args);               
                
return;
            }

#endif
            
// Do not use LoggingService here (see comment in Run(string[]))
            try
            
{
                Run(args);
            }

            
catch (Exception ex)
            
{
                
try
                
{
                    HandleMainException(ex);
                }

                
catch (Exception loadError)
                
{
                    
// HandleMainException can throw error when log4net is not found
                    MessageBox.Show(loadError.ToString(), "Critical error (Logging service defect?)");
                }

            }

        }


        
static void HandleMainException(Exception ex)
        
{
            LoggingService.Fatal(ex);
            
try
            
{
                MessageBox.Show(ex.ToString(), 
"Unhandled exception terminated");
            }

            
catch
            
{
                MessageBox.Show(ex.ToString(), 
"Critical error (cannot use ExceptionBox)");
            }

        }


        
static void Run(string[] args)
        
{
            Application.SetCompatibleTextRenderingDefault(
false);

            RunApplication();
        }


        
static void RunApplication()
        
{
            LoggingService.Info(
"Starting SharpDevelop...");
         
            
try
            
{

                
for (int i = 0; i < 10; i++)
                
{
                    LoggingService.Warn(i.ToString());
                }

            }

            
finally
            
{
                LoggingService.Info(
"Leaving RunApplication()");
            }

        }

    }

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值