一周总结
2026/6/1 10:27:32 网站建设 项目流程

LINQ 与 Lambda 表达式(C# 的“魔法”)

比较高级的 C# 特性:

  • Distinct():一行代码去重。

  • OrderByDescending():一行代码排序。逆序正序是orderby。

  • pair => pair.Value:理解了 Lambda 表达式其实就是一个“临时的筛选/排序规则”,告诉程序“我要按什么属性来操作”。这是在orderby方法中写来进行筛选。

Dictionary(字典)的核心威力

1.字典比列表(List)更强大的地方:查找速度快

这是源于他的特殊结构(数组加链表的特殊结构)

具体为两个数组,一个为查找,一个为存储

在数据数组中最小的单元是结构体,包含:

int hashCode缓存的哈希值。这是为了性能,下次扩容搬家时,直接拿这个值去算新位置,不用重新对 Key 进行复杂的哈希计算。

int next链表的“指针”。如果发生哈希冲突(撞车),这个值会指向同在这个桶里的“上一个”数据的下标。如果没有下一个,就是 -1。

TKey key:你存的键。

TValue value:你存的值。

在查找数组中存储着数据数组,数据数组在查找数组的下标是他的映射

字典会把键使用GetHashCode()转化为哈希值并除以查找数组的长度计算出一个数,这个数作为数据数组的下标,如果这个下标没有数组就存储,有的话就会用到链表,这时候上述next就会发挥作用。

查找数组也就是字典的长度在字典new出来时是0,因为他是懒加载,第一次插入add的时候扩容为3,往后会扩容为至少是当前容量 2 倍的最小质数。

2.不再需要遍历:以前找个商品要用foreach循环整个列表,现在直接用cart.ContainsKey("商品名")就能判断是否存在,效率极高。

3.直接拿数据:使用cart["商品名"]就能直接获取或修改对应的价格和数量,像查字典一样精准。

在使用泛型类使用<T>的时候遇到比较问题

在方法传入T a,T b想要进行比较传统使用< ,>会编译不通过,

方法1

可以使用compareto方法,但使用时必须继承IComparable接口

compareto具体可以比较

  • 数字类int,double,float,long,byte等(比大小)。

  • 文本类string,char(比字典顺序)。

  • 时间类DateTime(比早晚)。

  • 布尔类boolfalse小于true,虽然很少这么比)。

方法2

可以使用 dynamic来修饰需要比较的量

编译不会管dynamic类型会直接通过在出错时中断程序

文件操作中遇到的问题

在使用copy时需要的参数时需要文件名字的不是指定位置

比如我想把文件1.txt复制到d:\23文件夹需要的参数时d:\23\1.txt,这时用到提取文件名字方法Path.GetFileName()和拼接方法Path.Combine("D:\\", "文件名.txt")

遇到"The process cannot access the file... because it is being used by another process"时,明白了这是因为文件被锁住了

具体为在调用d盘的时候出错好像源路径是默认打开的

通配符概念 (Wildcards)

*.*的含义:明白了*代表任意字符。

  • *.*= 任意文件名 + 任意后缀(即所有文件)。

  • *.txt= 任意文件名 + txt 后缀(即仅 txt 文件)

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询