编辑
2025-10-07
C#
00

在C# .NET中,Func、Predicate和Expression是三种常用的委托和表达式类型,它们在编写灵活、可重用的代码时非常有用。本文将详细介绍这三种类型,并提供多个实例来说明它们的用法和区别。

1. Func<T, TResult>

Func是一个通用委托,它可以接受零个或多个输入参数,并返回一个值。其基本形式为:

C#
public delegate TResult Func<out TResult>(); public delegate TResult Func<in T, out TResult>(T arg); public delegate TResult Func<in T1, in T2, out TResult>(T1 arg1, T2 arg2); // ... 最多可以有16个输入参数

示例1:基本用法

C#
Func<int, int, string> formatNumber = (a, b) => $"The sum of {a} and {b} is {a + b}"; string result = formatNumber(5, 3); Console.WriteLine(result);

image.png

编辑
2025-10-07
C#
00

引言

在地理信息系统(GIS)、导航和位置服务等应用中,计算地球表面两点之间的距离是一个常见需求。本文将介绍如何使用C#和Gaversin公式来准确计算这个距离。

Gaversin公式简介

Gaversin公式(也称为Haversine公式)是计算球面上两点之间大圆距离的一种方法。在地球这个近似球体上,它可以给出两点间的最短距离。与简单的直线距离相比,Gaversin公式考虑了地球的曲率,因此在计算长距离时更为准确。

编辑
2025-10-07
C#
00

在处理大量数据插入时,SQL Bulk Insert是一种高效的方法。本文将介绍如何在C# .NET中使用SQL Bulk Insert,并提供多个实用示例。

1. 基本的Bulk Insert操作

首先,让我们看一个基本的Bulk Insert操作示例:

C#
public class BulkInsertExample { public void PerformBulkInsert(List<Customer> customers, string connectionString) { try { using (var connection = new SqlConnection(connectionString)) { connection.Open(); using (var bulkCopy = new SqlBulkCopy(connection)) { // 设置目标表名 bulkCopy.DestinationTableName = "Customers"; // 设置批量插入的大小 bulkCopy.BatchSize = 1000; // 映射列名 bulkCopy.ColumnMappings.Add("Id", "Id"); bulkCopy.ColumnMappings.Add("Name", "Name"); bulkCopy.ColumnMappings.Add("Email", "Email"); // 设置超时时间 bulkCopy.BulkCopyTimeout = 600; // 10分钟 var dataTable = ConvertToDataTable(customers); bulkCopy.WriteToServer(dataTable); } } } catch (Exception ex) { // 处理异常 Console.WriteLine($"批量插入时发生错误: {ex.Message}"); throw; } } private DataTable ConvertToDataTable(List<Customer> customers) { var dataTable = new DataTable(); // 添加列 dataTable.Columns.Add("Id", typeof(int)); dataTable.Columns.Add("Name", typeof(string)); dataTable.Columns.Add("Email", typeof(string)); // 添加行 foreach (var customer in customers) { dataTable.Rows.Add(customer.Id, customer.Name, customer.Email); } return dataTable; } } public class Customer { public int Id { get; set; } public string Name { get; set; } public string Email { get; set; } } // 使用示例 class Program { static void Main(string[] args) { // 连接字符串 string connectionString = System.Configuration.ConfigurationManager.AppSettings["ConnectionString" // 创建测试数据 var customers = new List<Customer> { new Customer { Id = 1, Name = "John Doe", Email = "john@example.com" }, new Customer { Id = 2, Name = "Jane Smith", Email = "jane@example.com" }, new Customer { Id = 3, Name = "Bob Johnson", Email = "bob@example.com" } }; // 创建BulkInsertExample实例 var bulkInsert = new BulkInsertExample(); try { // 执行批量插入 bulkInsert.PerformBulkInsert(customers, connectionString); Console.WriteLine("批量插入成功完成!"); } catch (Exception ex) { Console.WriteLine($"发生错误: {ex.Message}"); } } }
编辑
2025-10-07
C#
00

1. 简介

最早这个我是在20年前用vb写过,当时只是为了自己玩游戏写的,本文将详细介绍如何使用C#开发一个鼠标操作录制和回放工具。这个工具可以记录用户的鼠标移动和点击操作,并能够保存、加载和回放这些操作。

2. 核心功能

  • 录制鼠标移动和点击
  • 保存和加载录制的操作
  • 回放录制的操作
  • 支持循环回放
  • 全局热键控制

3. 主要类和结构

3.1 MouseEvent 类

C#
public class MouseEvent { public int X { get; set; } public int Y { get; set; } public bool IsLeftClick { get; set; } public MouseEvent(int x, int y, bool isLeftClick) { X = x; Y = y; IsLeftClick = isLeftClick; } }

这个类用于存储单个鼠标事件,包括鼠标位置和是否左键点击。

3.2 Form1 类

这是主窗体类,包含了所有的UI控件和核心逻辑。

image.png

编辑
2025-10-07
C#
00

高级C#开发人员经常利用反射和泛型来简化代码,提高效率。这些技巧可以帮助我们避免编写大量重复代码,同时提高代码的可维护性。本文将介绍几个使用反射和泛型的高级技巧,并提供详细的示例。

1. 使用Lambda表达式获取属性名称

在C#中,我们经常需要引用对象的属性名称。直接使用字符串硬编码属性名称可能会导致在重构时出现问题。使用Lambda表达式可以安全地获取属性名称,即使在重命名属性时也能保持代码的正确性。

C#
// 使用示例 class Person { public string Name { get; set; } } internal class Program { public static string PropertyName<TEntity, TProp>(Expression<Func<TEntity, TProp>> expression) { MemberExpression member = expression.Body as MemberExpression; return member.Member.Name; } static void Main(string[] args) { var nameProp = PropertyName((Person p) => p.Name); Console.WriteLine(nameProp); // 输出: "Name" } }

image.png