news 2026/4/18 7:52:13

【第16天】16c#今日小结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【第16天】16c#今日小结

1.泛型类

1泛型方法:只需要在方法名字后面加<T,T1,T2> 为了确定参数类型和返回值类型,当然也可以参数和返回值类型定义成普通类型

2 泛型类:在类名后面添加<T>,目的把类型传入类当中

3 泛型接口:在接口后面添加泛型,目的把类型传接口当中

//泛型字母可以写任意的字母 class People<TTest1,TTest2> { public string Name { get; set; } public TTest1 A1 { get; set; }// 属性的类型和传入TTest1类型保持一致 public TTest2 A2 { get; set; } // 属性的类型和传入TTest2类型保持一致 public void F1<T>(T c ,TTest1 a,TTest2 b) { dynamic sum = (dynamic)c + (dynamic)a + (dynamic)b; Console.WriteLine(sum); } } //泛型接口 interface IPeople<T> { int Age { get; set; } T Name { get; set; } void F1<T1>(T a,T1 b); } class Student : IPeople<float> { public int Age { get; set; } public float Name { get; set; } public void F1<T1>(float a, T1 b) { Console.WriteLine(a + b.ToString()); } }
static void Main(string[] args) { People<int,float> p1 = new People<int,float>(); //传入的int 和float类型 p1.F1<float>(10.1f, 10, 20.2f); People<string,string> p2 = new People<string,string>(); p2.F1<string>("+++++++", "---------", "红客联盟白宫服务网站挂上中国国旗"); Student s1 = new Student(); s1.Age = 10; s1.Name = 19.1f; s1.F1<int>(10, 20); Console.ReadKey(); }

2.泛型约束

泛型约束: 泛型本身没有限制类型但是通过 where对泛型进行限制范围

本身泛型没有类型限制的

where T : struct限制T只能值类型

where T : class限制T只能是引用类型

where T : new() T必须有一个不带参数的构造函数的类

where T : IPeople T必须是实现接口的类型 或者实现接口类的派生类, 本例可以是Student、还可以继承于Student的子类:SmallStudent

where T : U限制传入类型 要么是T和U同一个类型、要么T是U的子类

eg:

//本身泛型没有类型限制的 static void Test1<T>(T a) { } // where T : struct 限制T只能值类型 static void Test2<T>(T a,T b) where T : struct { } //where T : class 限制T只能是引用类型 static void Test3<T>(T a, T b) where T : class { } //where T : new() T必须有一个不带参数的构造函数的类 static void Test4<T>(T a, T b) where T : new() { } //where T : IPeople T必须是实现接口的类型 或者实现接口类的派生类, 本例可以是Student、还可以继承于Student的子类:SmallStudent static void Test5<T>(T a, T b) where T : IPeople { } // where T : U 限制传入类型 要么是T和U同一个类型、要么T是U的子类 static void Test6<T,U>(T a, U b) where T : U { } } interface IPeople { } //接口 class Student:IPeople { } // Student实现接口 class SmallStudent:Student { } // SmallStudent继承了 Student //定义people类 class People { public People() { } // 无参数构造 public People(int a) { }// 有参数的构造 }
static void Main(string[] args) { //调用Test1方法 Test1<int>(10); Test1("hello"); Test1(DateTime.Now); //调用Test2方法 Test2(10, 10); //Test2<DateTime,int>(DateTime.Now, 10);报错 //Test2("11", 10);报错 //调用Test3方法 Test3("11", "11"); // Test4方法 Test4(new People(),new People()); // Test5方法 Test5(new Student(), new SmallStudent()); //Test6方法 Test6(new People(), new People()); Test6(new SmallStudent(), new Student()); // Test6( new Student(), new SmallStudent()); 报错 Console.ReadKey(); }

3.hash表

hash表:和字典很类似,存储时候也是键值对的方法进行存储的,通过键获取对应的值,和字典不同地方在于,hash表存储键值对类型不固定

Hashtable hashtable = new Hashtable(); 创建hash表

1.添加键值对
hashtable.Add(1, 2);
hashtable.Add("name", "张三");

2 .查询键对应的值
Console.WriteLine(hashtable[1]);//获取对应键的值

3.遍历hash所有的keys
foreach (var item in hashtable.Keys)
{
Console.WriteLine(item+"--------");
}

4.遍历hash所有的values
foreach (var item in hashtable.Values)
{
Console.WriteLine(item + "+++++++");
}

5. 遍历hash所有键值对
foreach (DictionaryEntry item in hashtable)
{
Console.WriteLine(item.Value+"?????????");
}
Console.ReadKey();

6 .清空键值对
hashtable.Clear();

7.指定键进行移除
hashtable.Remove(1);

8 .包含这个键
Console.WriteLine(hashtable.ContainsKey("name"));

9. 修改
hashtable["name"] = "你好";

10. 键值对个数
Console.WriteLine(hashtable.Count);

4.堆栈_stack_和队列

本节是按照线性数据结构据,数存储方式进行对比的

栈:对要操作元素会进行一个后进先出的操作,例如:现实场景电梯,先进去的人最后才出来,后进去的人先出来
添加元素称为入栈
取出一个元素操作称为出栈

Stack<string> stack = new Stack<string>();---存放字符串栈结构 stack.Push("张三");--- 入栈 stack.Push("李四"); stack.Push("王五"); string name = stack.Pop();---出栈 Console.WriteLine(name+"-----");---王五 Console.WriteLine(stack.Peek()); ---获取栈顶元素 李四 Console.WriteLine(stack.Count); ---2个 //stack.Clear(); ---清空栈 //stack.ToArray() ; ---转成数组

队列:对元素进行先进先出的操作 例如现实场景排队买饭
添加元素一般入队操作
取出元素一般出队操作

Queue<string> queue = new Queue<string>(); queue.Enqueue("马化腾"); ---入队 queue.Enqueue("马云"); queue.Enqueue("马嘉祺"); Console.WriteLine(queue.Count); Console.WriteLine(queue.Dequeue()); ---出队马化腾 Console.WriteLine(queue.Peek());---获取队顶元素马云 // queue.Clear(); 清空队列

按照存储区域分别解释堆和栈


特性 栈(Stack) 堆(Heap)
存储内容 值类型、方法参数、局部变量 引用类型对象、装箱的值类型
生命周期 随作用域结束自动释放 由垃圾回收器(GC)管理
分配速度 快(指针移动) 慢(动态查找可用内存)
内存布局 连续内存 非连续(可能产生碎片)
访问方式 直接 通过引用间接访问
线程关联 每个线程独有 所有线程共享
管理方式 编译器自动管理 垃圾回收器(GC)管理

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 22:06:59

如何用anything-llm实现文档智能检索与对话交互?

如何用 Anything-LLM 实现文档智能检索与对话交互&#xff1f; 在企业知识库动辄上千份PDF、Word和Excel文件的今天&#xff0c;如何快速找到“那份说过但记不清在哪”的关键信息&#xff1f;传统搜索依赖关键词匹配&#xff0c;面对模糊提问常常束手无策&#xff1b;而通用大模…

作者头像 李华
网站建设 2026/4/17 18:43:19

System76发布Pop!_OS 24.04 LTS版搭载全新Rust构建的桌面环境

经过长时间的开发&#xff0c;第一个完全基于Rust构建的桌面环境1.0版本终于发布&#xff0c;整体表现令人印象深刻。上周末&#xff0c;System76正式发布了其内部开发的Ubuntu衍生版本的长期支持版本&#xff0c;同时推出了完全用Rust重新实现的内部桌面环境COSMIC的"Epo…

作者头像 李华
网站建设 2026/4/17 1:37:01

Pr字幕样式如何统一修改?简单3步,新手也能一次改完

如果你搜索到这篇文章&#xff0c;大概率只有一个想法&#xff1a; 字幕太多了&#xff0c;不想一条一条改。 不管是改字体、颜色&#xff0c;还是统一位置&#xff0c;只要字幕数量一多&#xff0c;用 Pr 原生方式操作&#xff0c;都会变得又慢又容易出错。 下面这套方法&…

作者头像 李华
网站建设 2026/4/17 23:54:48

低功耗设计:手机控制LED屏的节能策略

手机控制LED屏如何省电&#xff1f;揭秘三大低功耗核心技术你有没有想过&#xff0c;一块小小的LED显示屏&#xff0c;为什么能让智能手环撑上一周&#xff0c;而有些电子标签却几个月都不换电池&#xff1f;在物联网设备遍地开花的今天&#xff0c;手机通过蓝牙控制LED屏已经不…

作者头像 李华
网站建设 2026/4/17 1:27:35

MyBatis实战精讲:完整用户CRUD操作全解析

在Java持久层开发领域&#xff0c;MyBatis凭借其轻量化、高灵活性的特性&#xff0c;成为连接Java应用与数据库的主流框架。它摒弃了JDBC繁琐的代码编写&#xff0c;通过“接口XML”的映射模式&#xff0c;让开发者专注于SQL逻辑本身。本文将基于一套完整的用户数据操作代码&am…

作者头像 李华
网站建设 2026/4/17 5:04:54

【2025 arXiv】Reasoning Within the Mind: Dynamic Multimodal Interleaving in Latent Space

这篇论文的核心突破在于将多模态推理从“显式的文本生成”转移到了“隐式的潜在空间优化”,并利用“置信度”这一信号实现了类似人类的动态视觉回溯,从而兼顾了推理的深度、准确性和效率。 paper: https://arxiv.org/pdf/2512.12623 code: https://github.com/eric-ai-lab/DM…

作者头像 李华