我试图围绕.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("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万只当然实际上这是估算的,具体应…