在 C# 中记录复杂对象
调试代码时,在运行时查看对象的状态通常很有帮助。 Visual Studio 的立即窗口提供了一种使用语法 ? 显示对象的格式化内容的便捷方法。
要在代码中实现此目的以进行日志记录,可以考虑以下几种方法:
JSON 序列化:
一种有效的方法转储大型对象图正在使用 JSON 序列化。这可以使用 Newtonsoft.Json 库来完成:
using Newtonsoft.Json; public static class ObjectDumper { public static string Dump(object obj) { return JsonConvert.SerializeObject(obj); } }
在立即窗口中,您可以执行以下命令:
var logEntry = ObjectDumper.Dump(myObj);
要可视化 JSON 结构,请展开 logEntry在“局部”窗口中输入值,然后从放大镜旁边的下拉插入符号中选择“Json 可视化工具”选项icon.
Reflection 和 ToString():
另一种方法是使用 Reflection 来访问对象的属性和值,并手动将它们转换为字符串表示形式:
public static string Dump(object obj) { StringBuilder sb = new StringBuilder(); Type type = obj.GetType(); PropertyInfo[] properties = type.GetProperties(); sb.Append("Object of type: " + type.Name + "\n"); foreach (PropertyInfo property in properties) { sb.Append(property.Name + ": "); sb.Append(property.GetValue(obj)?.ToString() ?? "null"); sb.Append("\n"); } return sb.ToString(); }
其他选项:
以上是如何有效地记录 C# 中的复杂对象以进行调试?的详细内容。更多信息请关注PHP中文网其他相关文章!