如何将日志记录集成到.NET代码协定中 - c#

我试图围绕.NET的代码合同。使用代码协定时,如何记录断言导致相关方法失败。例如,看下面的代码:

  Public IsMatch(string x, string, y) 
{ 

    Contract.Assert(!string.IsNullOrWhiteSpace(x)); 
     Contract.Assert(!String.IsNullOrWhitespace(y));

       return x == y;
 }

假设x = string.Empty。这将导致方法失败。我如何记录断言导致上述方法失败。在大型应用程序中,我可以有许多这样的主张,并且很高兴知道哪个是麻烦制造者。

参考方案

使用代码协定时,如何记录断言导致相关方法失败?

如果您正在谈论日志记录,那么我假设您的意思是在运行时而不是静态验证。

断言在失败时引发异常。您可以编写一个try / catch块来记录异常:

try
{
    bool result = SomeClass.IsMatch(x, y);
}
catch(Exception e)
{
    logger.Error(e.ToString()); // Use whatever logging mechanism here
    throw; // Note: Make sure you rethrow if you catch "Exception e"
}

这将为您提供异常的堆栈跟踪,该异常将指向断言失败的行。

如Polity所述,您还可以在每个断言中包含一个userMessage参数。这样,除了堆栈跟踪之外,您的日志还将包含自定义错误消息。

如果您需要一个好的logger类,请查看the NLog library。

java.net.URI.create异常 - java

java.net.URI.create("http://adserver.adtech.de/adlink|3.0") 抛出java.net.URISyntaxException: Illegal character in path at index 32: http://adserver.adtech.de/adlink|3.0 虽然n…

在ASP.NET WebForms中在服务器端初始化bootsrap datatimepicker - javascript

我有这个HTML<div class='datepicker input-group date' id='datetimepickerStart'> <input type='text' class="form-control" /> <span c…

各种Microsoft.CodeQuality。*分析器之间有什么区别? - c#

我对.NET Core的各种代码分析器感到有些困惑。如果创建默认的.NET Core Web项目,则会得到Microsoft.CodeAnalysis.Analyzers。另外,在NuGet上,有Microsoft.CodeQuality.Analyzers(注意名称略有不同)。安装后,我发现它包含更多规则。最后,还有Microsoft.CodeAnalys…

LeetCode题解计算机为什么是基于二进制的?

可以是三进制么?二进制有什么好处?题解:为什么叫电子计算机?算盘应该没有二进制

LeetCode题解统计城市的所有灯泡

这个是我刚毕业的时候,一个真实的面试题,这是一个开放题。题目描述:想办法,将一个城市的所有灯泡数量统计出来。题解:费米估算法1、如果某个城市常驻人口有1000万2、假设每5人居住在一套房里,每套房有灯泡5只,那么住宅灯泡共有1000万只3、假设公众场所每10人共享一只灯泡,那么共有100万只4、主要的这两者相加就得出了1100万只当然实际上这是估算的,具体应…