C#入门经典(第6版)阅读笔记(第六篇)(LINQ)

本文介绍了LINQ的基础概念、关键字及使用方法,包括from、where、select等子句的应用,并通过实例演示了如何创建和执行LINQ查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一篇 基础知识点

  • LINQ关键字
  • from 指定数据源和范围变量
  • where 根据布尔表达式(由逻辑与 或 等组成)从数据源中筛选元素
  • select 指定查询结果中的元素所具有的类型或表现形式
  • group 对对查询结果按照键值进行分组
  • into 提供一个标示符,它可以充当对 join group 或 select 子句结果的引用
  • orderby 对查询出的元素进行排序
  • join 按照两个指定匹配条件来联接俩个数据源
  • let 产生一个用于查询表达式中子表达式查询结果的范围变量
1.1 概述

LINQ的全称是Language Integrated Query,中文译成“语言集成查询”。LINQ作为一种查询技术,首先要解决数据源的封装,大致使用了三大组件来实现这个封装,分别是LINQ to Object、LINQ to ADO.NET、LINQ to XML。它们和.NET语言的关系如下:

2789632-139d5ab78ab849f0.png
1.2 组成

LINQ的查询由3基本部分组成:获取数据源,创建查询,执行查询。

            // 1,获取数据源
            List<int> numbers = new List<int>() { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };

            // 2,创建查询
            var numQuery = from num in numbers
                           where num % 2 == 0
                           select num;

            // 3,执行查询
            foreach (var num in numQuery)
            {
                Console.WriteLine("{0,1}", num);
            }
2789632-ad6f8d4a12a8fd88.png
完整的查询操作
1.3 样例

代码:

static void Main(string[] args)
        {
            //获取数据源
            string[] names = { "Alen", "Zhen", "Chen","Song", "Hel", "Ken", "Aln", "Zen", "Cen", "He", "Ke", };
            //创建查询
            var queryResults = from n in names where n.StartsWith("S") select n;
            Console.WriteLine("Names beginning with S:");
            //执行查询
            foreach (var item in queryResults)
            {
                Console.WriteLine(item);
            }
            Console.Write("Program finished,press Enter/Reurn to continue:");
            Console.ReadLine();
        }
2789632-3b236da075f9f153.png
执行结果

第二篇 语句使用方式

2.1 from子句

** 创建一个LINQ表达式必须要以from子句开头。**

2.1.1 单个form子句

样例:

 //获取数据
            string[] a = { "日本","德国","英国","美国","澳大利亚"};
            //创建查询,创建一个LINQ表达式必须要以from子句开头
            var myQuery = from n in a where n.IndexOf("国") > 0 select n;
            //执行查询
            foreach(var item in myQuery)
            {
                Console.WriteLine(item);
            }
            Console.ReadKey();
2789632-f58fefb1440df935.png

样例:(查询List<T>集合)
代码:

namespace LINQ查询1
{
    //定义一个信息类
    public class CustomerInfo
    {
        public string Name { get; set; }
        public int Age { get; set; }
        public string Tel { get; set; }
    }
    class Test02_LINQList
    {
        static void Main(string[] args)
        {
            //使用对象和集合的初始化器
            //获取数据源
            List<CustomerInfo> customers = new List<CustomerInfo>
        {
            new CustomerInfo{Name = "杨铁心",Age = 100,Tel = "12332112332"},
            new CustomerInfo{Name = "杨康", Age = 80,Tel = "45654546565"},
            new CustomerInfo{Name = "杨过", Age = 60,Tel = "89979879789"}
        };
            //创建查询
            var query = from CustomerInfo ci in customers
                        where ci.Age >= 80
                        select ci;
            //执行查询
            foreach (CustomerInfo ci in query)
            {
                Console.WriteLine("姓名:{0} 年龄:{1} 电话:{2}",ci.Name,ci.Age,ci.Tel);
            }
            Console.ReadKey();
        }
    }
}
2789632-8743e0b145ef3708.png
运行结果
2.1.2 复合from子句

样例:
代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace LINQ查询1
{
    public class CustomerInfo1
    {
        public string Name { get; set; }
        public int Age { get; set; }
        public List<string> TelTable { get; set; }
    }
    class Test03_MultiFrom
    {
        static void Main(string[] args)
        {
            //获取数据源
            List<CustomerInfo1> customer = new List<CustomerInfo1>
            {
                new CustomerInfo1{Name = "郭啸天",Age = 100,TelTable = new List<string>{"123321","321123"}},
                new CustomerInfo1{Name = "郭靖",Age = 80,TelTable = new List<string>{"456654","654456"}},
                new CustomerInfo1{Name = "郭芙", Age = 60,TelTable = new List<string>{"789987","987789"}}
            };
            //创建查询
            var query = from CustomerInfo1 ci in customer
                        from tel in ci.TelTable
                        where tel.IndexOf("789987") > -1
                        select ci;
            //执行查询
            foreach (var item in query)
            {
                Console.WriteLine("姓名:{0} 年龄:{1}",item.Name,item.Age);
                foreach (var tel in item.TelTable)
                {
                    Console.WriteLine("电话:{0}",tel);
                }
            }
            Console.ReadKey();

        }
    }
}

2789632-db856eba5c10e8b7.png
2789632-415c6acd3a6c6ca0.png
2.2 where 语句
  • where子句的作用就是筛选元素,除了开始和结束位置, where子句几乎可以出现在LINQ表达式的任意位置。
  • 一个LINQ表达式中可以有where子句,也可以没有;可以有一个,可以有多个;
  • 多个where子句之间的关系相当于逻辑“与”,每个where子句可以包含1个或多个逻辑表达式,这些条件成为“谓词”,多个谓词之间用布尔运算符隔开,比如逻辑“与”用&&,逻辑“或”用||,而不是用SQL中的AND或OR。
    2.2.1 常见查询
2789632-383365497f8d31d2.png

2.2.2 自定义函数

2789632-51948c0acbc797cd.png

2.2.3 动态谓词的筛选

2789632-475f0b4eb3d0b432.png
2.3 select子句
2.3.1 输出查询结果
2789632-0b3af2909ef67074.png
2.3.2 对查询结果进行投影

代码:

 public class MyCustomerInfo
    {
        public string Name { get; set; }
        public string Tel { get; set; }
    }
    class Test04_whereExpDemo
    {
        static void Main(string[] args)
        {
            //获取数据源
            List<CustomerInfo> clist = new List<CustomerInfo>
            {
                new CustomerInfo{Name = "李白",Age = 88,Tel = "123321"},
                new CustomerInfo{Name = "杜甫", Age = 77,Tel = "456654"},
                new CustomerInfo{Name = "白居易", Age = 66,Tel = "123321"}
            };
            //定义动态的谓词数组,这个数组应该由实际运行环境生成
            string[] names = {"李白","杜甫","辛弃疾" };
            //查询在给定谓词数组里存在的客户(创建查询)
            var query = from customer in clist
                        where customer.Age < 90
                        select new MyCustomerInfo { Name = customer.Name, Tel = customer.Tel };//类型转换   
            //执行查询
            foreach (var ci in query)
            {
                Console.WriteLine("姓名:{0} 电话:{1} 类型{2}",ci.Name,ci.Tel,ci.GetType().FullName);
            }

            Console.ReadKey();
        }
    }
2789632-cffb4d5d2099830d.png

个人认为就是利用select对查询结果做了一个类型转换。

2.4 Group 子句

按照语法的规定,LINQ表达式必须以from子句开头,以select或group子句结束,所以除了使用select子句外,也可以使用guoup子句来返回元素分组后的结果。group子句返回的是一个IGrouping<TKey,TElement>泛型接口的对象集合。

2789632-1fdb98d615c0d0c4.png
2789632-d03a576e8fd59d00.png
2789632-44fff7a781db66fd.png
2.5 into 子句

into子句作为一个临时标识符,用于select,group,join子句中。

2789632-74668e7b540c393f.png

   into子句提供了一个临时标识符,它存储了into子句前面的查询内容,使它后面的子句可以方便的使用,对其进行再次查询,投影等操作。

2.6 排序子句

2.6.1 OrderBy和OrderByDescending

2789632-79b07f6cf2d910ad.png

2.6.2 ThenBy和ThenByDescending

2789632-8889fcd362b137a7.png
2.7 let 子句

let子句用于在LINQ表达式中存储子表达式的计算结果。let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它。此范围变量可以再后续的LINQ子句中使用。

2789632-89a4aa9218cac9be.png
2.8 join子句

如果一个数据源中元素的某个属性可以跟另一个数据源中元素的属性进行相等比较,那么这两个数据源可以用join子句进行关联。jion子句用equals关键字进行比较,而不是常见的==。

2789632-ecc9ae385505555d.png

2789632-3b18269684ea9294.png
公众号.png
资源下载链接为: https://pan.quark.cn/s/abbae039bf2a 无锡平芯微半导体科技有限公司生产的A1SHB三极管(全称PW2301A)是一款P沟道增强型MOSFET,具备低内阻、高重复雪崩耐受能力以及高效电源切换设计等优势。其技术规格如下:最大漏源电压(VDS)为-20V,最大连续漏极电流(ID)为-3A,可在此条件下稳定工作;栅源电压(VGS)最大值为±12V,能承受正反向电压;脉冲漏极电流(IDM)可达-10A,适合处理短暂高电流脉冲;最大功率耗散(PD)为1W,可防止器件过热。A1SHB采用3引脚SOT23-3封装,小型化设计利于空间受限的应用场景。热特性方面,结到环境的热阻(RθJA)为125℃/W,即每增加1W功率损耗,结温上升125℃,提示设计电路时需考虑散热。 A1SHB的电气性能出色,开关特性优异。开关测试电路及波形图(图1、图2)展示了不同条件下的开关性能,包括开关上升时间(tr)、下降时间(tf)、开启时间(ton)和关闭时间(toff),这些参数对评估MOSFET在高频开关应用中的效率至关重要。图4呈现了漏极电流(ID)与漏源电压(VDS)的关系,图5描绘了输出特性曲线,反映不同栅源电压下漏极电流的变化。图6至图10进一步揭示性能特征:转移特性(图7)显示栅极电压(Vgs)对漏极电流的影响;漏源开态电阻(RDS(ON))随Vgs变化的曲线(图8、图9)展现不同控制电压下的阻抗;图10可能涉及电容特性,对开关操作的响应速度和稳定性有重要影响。 A1SHB三极管(PW2301A)是高性能P沟道MOSFET,适用于低内阻、高效率电源切换及其他多种应用。用户在设计电路时,需充分考虑其电气参数、封装尺寸及热管理,以确保器件的可靠性和长期稳定性。无锡平芯微半导体科技有限公司提供的技术支持和代理商服务,可为用户在产品选型和应用过程中提供有
资源下载链接为: https://pan.quark.cn/s/9648a1f24758 在 JavaScript 中实现点击展开与隐藏效果是一种非常实用的交互设计,它能够有效提升用户界面的动态性和用户体验。本文将详细阐述如何通过 JavaScript 实现这种功能,并提供一个完整的代码示例。为了实现这一功能,我们需要掌握基础的 HTML 和 CSS 知识,以便构建基本的页面结构和样式。 在这个示例中,我们有一个按钮和一个提示框(prompt)。默认情况下,提示框是隐藏的。当用户点击按钮时,提示框会显示出来;再次点击按钮时,提示框则会隐藏。以下是 HTML 部分的代码: 接下来是 CSS 部分。我们通过设置提示框的 display 属性为 none 来实现默认隐藏的效果: 最后,我们使用 JavaScript 来处理点击事件。我们利用事件监听机制,监听按钮的点击事件,并通过动态改变提示框的 display 属性来实现展开和隐藏的效果。以下是 JavaScript 部分的代码: 为了进一步增强用户体验,我们还添加了一个关闭按钮(closePrompt),用户可以通过点击该按钮来关闭提示框。以下是关闭按钮的 JavaScript 实现: 通过以上代码,我们就完成了点击展开隐藏效果的实现。这个简单的交互可以通过添加 CSS 动画效果(如渐显渐隐等)来进一步提升用户体验。此外,这个基本原理还可以扩展到其他类似的交互场景,例如折叠面板、下拉菜单等。 总结来说,JavaScript 实现点击展开隐藏效果主要涉及 HTML 元素的布局、CSS 的样式控制以及 JavaScript 的事件处理。通过监听点击事件并动态改变元素的样式,可以实现丰富的交互功能。在实际开发中,可以结合现代前端框架(如 React 或 Vue 等),将这些交互封装成组件,从而提高代码的复用性和维护性。
一、AutoCAD 2016的工作界面 组成要素:由应用程序菜单、标题栏、快速访问工具栏、菜单栏、功能区、命令窗口、绘图窗口和状态栏组成。 1. 切换至AutoCAD 2016 1)工作空间 模式类型:提供草图与注释、三维基础、三维建模三种工作空间模式 二维绘图功能:在草图与注释空间中可使用默认、插入、注释、参数化、视图管理等选项卡进行二维图形绘制 切换方法: 快速访问工具栏→工作空间按钮下拉列表 状态栏→切换工作空间按钮下拉列表 三维功能:三维基础空间包含可视化、坐标、长方体等三维建模工具 2)应用程序菜单 位置:位于界面左上角 核心功能: 搜索命令 文件操作(新建/打开/保存/另存为/输出/发布/打印/关闭) 最近文档管理(可按日期/大小/类型排序) 选项设置(打开选项对话框) 3)标题栏 显示内容:当前程序名称(Autodesk AutoCAD 2016)和文件名称 信息中心功能: 帮助搜索 Autodesk账户登录 软件更新检查 窗口控制(最小化/最大化/关闭) 4)菜单栏 显示设置:通过自定义快速访问工具栏→显示菜单栏选项启用 菜单结构:包含文件、编辑、视图、插入等11个主菜单项 命令示例: 绘图→直线:进入直线绘制模式 绘图→圆弧:提供三点、起点-圆心-端点等11种绘制方式 5)选项卡和面板 组织结构: 选项卡(默认/插入/注释等) 面板(绘图/修改/注释等) 命令按钮(直线/多段线/圆等) 操作流程:单击命令按钮→绘图区操作→Enter键确认 6)工具栏 调用方式:工具→工具栏→AutoCAD→选择所需工具栏 控制方法: 显示:勾选对应工具栏选项 隐藏:取消勾选或点击工具栏关闭按钮 示例操作:绘图工具栏包含直线、构造线等绘图工具按钮 7)绘图窗口 主要功能:核心绘图工作区域 导航控制: 滚动条调整视图 模型/布局空间切换 显示
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值