0

你怎么看?我正在尝试创建一种log方法。我想知道如何使用以下调用语法来定义它:

logging(var loggerContext = new LogManager(input)){ // create a new logger context and store input 

   //var results = Method();

} // store results in logger context

如何实现日志记录?

4

3 回答 3

3

我经常使用的另一种模式是这样的:

void WithLogging(Action action)
{
    // set up logging here
    action();
    // save results here
}

然后你可以像这样使用它:

WithLogging(() =>
{
    //do some things here
});
于 2013-03-18T14:13:49.890 回答
1

正如其他发帖者所指出的,定义新关键字不是您可以在 C# 中做的事情。您可能会发现Boo很有趣,尤其是宏。

于 2013-03-18T14:09:30.133 回答
0

有时在构造函数和方法IDisposable中使用自定义逻辑来实现这种情况是有意义的:Dispose

class Logmanager : IDisposable
{
    public Logmanager()
    {
        this.Log("Start");
    }

    private void Log(string message)
    {
        // some logging implementation
    }

    public void Dispose()
    {
        this.Log("Finish");
    }
}

然后你可以把它放在using语句中:

using (var logger = new Logmanager())
{
    // you can add something to logger here, e.g. store results
}
于 2013-03-18T14:03:14.623 回答