我在泛型类上应用DebuggerDisplay
属性时遇到问题:
[DebuggerDisplay("--foo--")]
class Foo
{
}
[DebuggerDisplay("Bar: {t}")]
class Bar<T>
{
public T t;
}
检查Bar<Foo>
类型的对象时,我希望它显示为Bar: --foo--
,但我得到Bar: {Foo}
我做错了什么?
答案 0 :(得分:19)
DebuggerDisplay属性不是递归的。字符串中的{}基本上是评估此表达式并以内联方式显示结果。计算内部结果的字符串,就好像没有类型或成员的DebuggerDisplay属性。这就是为什么你看到{Foo}而不是--foo--。
原因是可靠性。拥有相互递归的DebuggerDisplay属性标签太容易了。这会在评估内部表达式时导致堆栈溢出或无限循环。不递归地评估DebuggerDisplay属性会阻止此无限递归(尽管用户仍然可以在特定表达式中自己创建它)。
您可以通过覆盖.ToString()方法来控制内部表达式显示方式的一种方法。在计算内部表达式的显示字符串时,将对此进行评估。
答案 1 :(得分:2)
答案 2 :(得分:1)
您可以使用[DebuggerDisplay("Bar<{typeof(T).Name}>,nq}")]//nq - no quotes
。
您也可以使用以下做法: DebuggerDisplay attribute best practices