探索 C# 常用第三方库与框架

embedded/2024/10/21 5:45:09/

在 C# 开发中,第三方库和框架极大地提高了开发效率和代码质量。通过这些库,开发者可以快速处理 JSON 数据、简化对象映射、记录日志、以及高效地与数据库交互。本文将介绍四个常用的 C# 第三方库:Newtonsoft.JsonAutoMapperNLog/Serilog 以及 Dapper,并讲解它们的功能和使用方式。


1. Newtonsoft.Json 库

Newtonsoft.Json 是 C# 中处理 JSON 的最流行库之一,它为 JSON 序列化、反序列化、以及复杂的 JSON 操作提供了简洁的 API。无论是处理简单的数据结构还是嵌套对象,Newtonsoft.Json 都能够快速高效地进行操作。

安装 Newtonsoft.Json

你可以通过 NuGet 安装这个库:

Install-Package Newtonsoft.Json

序列化与反序列化

  • 序列化 是将 C# 对象转换为 JSON 格式的过程。
  • 反序列化 是将 JSON 数据转换为 C# 对象的过程。
using Newtonsoft.Json;public class Person
{public string Name { get; set; }public int Age { get; set; }
}var person = new Person { Name = "Alice", Age = 30 };// 序列化对象为 JSON 字符串
string json = JsonConvert.SerializeObject(person);
Console.WriteLine(json);  // 输出:{"Name":"Alice","Age":30}// 反序列化 JSON 字符串为对象
var deserializedPerson = JsonConvert.DeserializeObject<Person>(json);
Console.WriteLine(deserializedPerson.Name);  // 输出:Alice

处理复杂 JSON

Newtonsoft.Json 还支持处理复杂的 JSON 对象和嵌套结构。通过 JObject,你可以动态解析 JSON 数据。

var json = @"{ 'Name': 'Alice', 'Details': { 'Age': 30, 'Country': 'USA' } }";
var jsonObject = JObject.Parse(json);
Console.WriteLine(jsonObject["Details"]["Country"]);  // 输出:USA

2. AutoMapper

AutoMapper 是一个对象-对象映射器,简化了模型之间的转换过程。在开发中,通常需要将一个对象的属性映射到另一个对象,尤其是在处理 DTO(数据传输对象)和数据库实体时。AutoMapper 可以帮助你自动完成这些映射,减少手动编写代码的麻烦。

安装 AutoMapper

使用 NuGet 安装 AutoMapper:

Install-Package AutoMapper

设置与使用 AutoMapper

using AutoMapper;public class Source
{public string Name { get; set; }public int Age { get; set; }
}public class Destination
{public string FullName { get; set; }public int Age { get; set; }
}var config = new MapperConfiguration(cfg =>
{cfg.CreateMap<Source, Destination>().ForMember(dest => dest.FullName, opt => opt.MapFrom(src => src.Name));
});var mapper = config.CreateMapper();
var source = new Source { Name = "Alice", Age = 30 };
var destination = mapper.Map<Destination>(source);Console.WriteLine(destination.FullName);  // 输出:Alice
Console.WriteLine(destination.Age);  // 输出:30

在这个例子中,我们使用 CreateMap<Source, Destination> 定义了从 Source 到 Destination 的映射规则,并通过 Map 方法将源对象映射到目标对象。


3. NLog/Serilog 日志记录

日志记录是应用程序开发中非常重要的部分,它帮助开发者监控和调试应用程序。NLog 和 Serilog 是两个流行的 C# 日志记录库,它们提供了灵活的配置和强大的日志功能。你可以根据需求选择其中任意一个进行日志记录。

安装 NLog

使用 NuGet 安装 NLog:

Install-Package NLog

使用 NLog

using NLog;public class Program
{private static readonly Logger Logger = LogManager.GetCurrentClassLogger();public static void Main(string[] args){Logger.Info("Application started.");try{// 模拟应用程序逻辑throw new Exception("Something went wrong");}catch (Exception ex){Logger.Error(ex, "An error occurred");}}
}

通过 NLog 的配置文件 nlog.config,你可以控制日志输出的格式、文件路径等。

安装 Serilog

使用 NuGet 安装 Serilog:

Install-Package Serilog

使用 Serilog

using Serilog;public class Program
{public static void Main(string[] args){Log.Logger = new LoggerConfiguration().WriteTo.Console().WriteTo.File("logs/myapp.txt", rollingInterval: RollingInterval.Day).CreateLogger();Log.Information("Application started.");Log.CloseAndFlush();}
}

Serilog 支持结构化日志,允许记录详细的对象信息,提供更好的日志分析体验。


4. Dapper 微型 ORM

Dapper 是一个轻量级的微型 ORM,它提供了高效的数据库查询功能,并保留了 SQL 的灵活性。Dapper 是执行 SQL 查询和映射数据库结果集到 C# 对象之间的桥梁,适用于不需要复杂对象关系映射的应用场景。

安装 Dapper

通过 NuGet 安装 Dapper:

Install-Package Dapper

使用 Dapper

using System.Data.SqlClient;
using Dapper;public class Product
{public int ProductId { get; set; }public string ProductName { get; set; }public decimal Price { get; set; }
}var connectionString = "your_connection_string";
using (var connection = new SqlConnection(connectionString))
{var products = connection.Query<Product>("SELECT * FROM Products").ToList();foreach (var product in products){Console.WriteLine($"{product.ProductName}: {product.Price}");}
}

在这个示例中,我们通过 Dapper 的 Query 方法执行 SQL 查询,并将结果映射到 Product 对象。Dapper 提供了简洁的 API,适合需要直接编写 SQL 语句的开发者使用。


结论

C# 的第三方库和框架为开发者提供了丰富的工具,帮助简化开发过程并提升代码效率。通过使用 Newtonsoft.Json 来处理 JSON 数据,AutoMapper 来自动进行对象映射,NLog/Serilog 来进行日志记录,以及 Dapper 来快速访问数据库,开发者可以专注于业务逻辑,减少重复代码的编写。

  • Newtonsoft.Json 是处理 JSON 数据的强大工具,简化了序列化与反序列化操作。
  • AutoMapper 提供了自动对象映射的功能,减少了手动编写映射代码的麻烦。
  • NLog/Serilog 提供了灵活的日志记录功能,帮助开发者监控和调试应用程序。
  • Dapper 是高效的微型 ORM,适合需要直接控制 SQL 查询的场景。

通过掌握这些常用的第三方库和框架,开发者可以更加高效地构建可靠、可维护的 C# 应用程序。如果你有任何问题或者需要更多的示例,欢迎继续探讨!


这篇博客介绍了常用的 C# 第三方库和框架。如果你有任何疑问或需要更多详细示例,欢迎联系我!


http://www.ppmy.cn/embedded/127801.html

相关文章

复合泊松过程方差推导

全方差公式&#xff08;Law of Total Variance&#xff09;&#xff0c;描述了如何通过条件期望和条件方差分解总体方差。该定理适用于任何随机变量 ( X ) 和条件随机变量 ( Y )&#xff0c;公式如下&#xff1a; Var ( X ) E [ Var ( X ∣ Y ) ] Var ( E [ X ∣ Y ] ) \text…

牛客周赛 Round 62:小红的中位数查询easy:巧用stl模拟

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 easy 版本中&#xff0c;所有的 r−l1r - l 1r−l1 都相等&#xff0c;而 hard 版本中没有此限制。通过 easy 版本可以获得 250 分&#xff0c;通过 hard 版本可以获得 50 分。 小红…

HBO 纪录片揭露中本聪是谁

10 月 8 日播出的 HBO 纪录片《Money Electric: The Bitcoin Mystery》声称中本聪就是前加拿大比特币开发者 Peter Todd。 但纪录片上映前 Todd 在发送给 CoinDesk 的一封电子邮件中否认了这一点。 在纪录片中&#xff0c;导演 Cullen Hoback 根据他搜索的新旧线索得出了这一…

如何禁用Spring Boot启动时显示的横幅(banner)

引言 Spring Boot 在启动时会显示一个横幅&#xff08;banner&#xff09;&#xff0c;这个横幅通常包含 Spring Boot 的 logo 和一些启动信息。如果您不希望在控制台或日志文件里显示这个横幅&#xff0c;可以通过以下几种方式进行配置&#xff1a; 通过配置文件禁用横幅 通…

2.4.ReactOS系统运行级别降低IRQL级别KfLowerIrql 函数

2.4.ReactOS系统运行级别降低IRQL级别KfLowerIrql 函数 2.4.ReactOS系统运行级别降低IRQL级别KfLowerIrql 函数 文章目录 2.4.ReactOS系统运行级别降低IRQL级别KfLowerIrql 函数KfLowerIrql 函数 KfLowerIrql 函数 /*******************************************************…

软媒市场新蓝海:软文媒体自助发布与自助发稿的崛起

在信息时代的浪潮中,软媒市场以其独特的魅力和无限的潜力,成为了企业营销的新宠。随着互联网的飞速发展,软文媒体自助发布平台应运而生,为企业提供了更加高效、便捷的营销方式。而自助发稿功能的加入,更是让软媒市场的蓝海变得更加广阔。 软媒市场的独特价值 软媒市场之所以能…

解决 CentOS 安装 Oracle 11g 时的多架构依赖冲突20241014

解决 CentOS 安装 Oracle 11g 时的多架构依赖冲突 在 CentOS 中安装 64 位的 Oracle 11g 时&#xff0c;可能会遇到 Protected multilib versions 错误。该错误通常是由于系统中同时存在不同架构&#xff08;如 x86_64 和 i686&#xff09;的同一软件包版本不一致所导致。本文…

24/10/14 算法笔记 循环神经网络RNN

RNN: 一种专门用于处理序列数据的神经网络&#xff0c;它能够捕捉时间序列中的动态特征。RNN的核心特点是其循环连接&#xff0c;这允许网络在不同时间步之间传递信息&#xff0c;从而实现对序列数据的记忆和处理能力。 应用的场景&#xff1a; 自然语言处理&#xff08;NLP&…