首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

编写高质量代码:改善C#程序的157个建议

类型转换的方法 类型转换运算符(operator重载),例如 float j=0; int i = (int)j;。...不要用List作为自定义集合类的基类 因为List没有virtual方法,无法重写,因此最好自己实现一个集合类的基类。...迭代器应当是只读的 注意集合类型成员的可访问性 如果集合类型的属性是可写的,则可能引发线程安全的问题(建议22)。...使用匿名类型存储LINQ查询结果 在查询中使用Lambda表达式 实际上我只用Lambda表达式,因为个人认为LINQ的查询语法相当怪异,像SQL又有不同,看上去很别扭。...理解延迟求值和主动求值的区别 LINQ查询表达式并没有立即执行,只有在执行ToList()或者遍历时才会执行。

2.6K30

由浅入深表达式树(二)遍历表达式树

为什么要学习表达式树?表达式树是将我们原来可以直接由代码编写的逻辑以表达式的方式存储在树状的结构里,从而可以在运行时去解析这个树,然后执行,实现动态的编辑和执行代码。...LINQ to SQL就是通过把表达式树翻译成SQL来实现的,所以了解表达树有助于我们更好的理解 LINQ to SQL,同时如果你有兴趣,可以用它创造出很多有意思的东西来。   ...本文主要内容: 有返回值的表达式树示例 通过表达式树访问类翻译SQL查询Where语句   上一篇由浅入深表达式树(一)我们主要讨论了如何根据Lambda表达式以及通过代码的方式直接创建表达式树。...,将该Where方法转换成表达式树,只不过我们没有调用Provider的方法,而是直接让另一个类去将它翻译成SQL语句,然后直接返回该SQL语句。...重写IQuerable的Where方法,构造MethodCallExpression传给我们的表达式访问类。 在我们的表达式访问类中重写相应的具体访问方法。

1.1K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    .NET中数据访问方式(一):LINQ

    可查询类型无需额外操作即可进行LINQ操作,若数据源在内存中不以可查询类型的形式存在,那么LINQ提供程序必须要先将数据源转换为可查询类型,如LINQ to XML将XML文件转换为可查询的XElement...LINQ查询包含三个步骤: 获取数据源 创建查询语句 执行查询 LINQ查询方式 LINQ 表达式(又称为查询表达式) 以from关键字开头,select关键字结尾。...表达式和扩展方法在编译后的代码没有什么区别 对于排序、分组、联合查询使用LINQ表达式更为方便 //以排序为例,使用年龄、姓名、邮箱进行排序, //LINQ表达式中使用逗号分隔排序字段,而扩展方法则需要多次调用相应的扩展方法...LINQ查询特点: 延迟查询 若查询表达式的返回结果是IEnumerable类型,则在声明查询表达式时不会执行查询,而是在迭代查询变量时才进行查询。...LINQ表达式中的查询关键字 表格中的英文没什么难点,就不翻译了 :) 关键字 描述 from Specifies a data source and a range variable (similar

    2.7K30

    一步一步学Linq to sql(一):预备知识

    什么是Linq to sql   Linq to sql(或者叫DLINQ)是LINQ(.NET语言集成查询)的一部分,全称基于关系数据的 .NET 语言集成查询,用于以对象形式管理关系数据,并提供了丰富的查询功能...定义一个临时的匿名类型在LINQ查询句法中非常常见,我们可以很方便的实现对象的转换和投影。...LINQ查询运算符来表达查询时一个方便的声明式简化写法。...编译器在底层把查询句法的表达式翻译成明确的方法调用代码,代码通过新的扩展方法和Lambda表达式语言特性来实现。...  LINQ查询句法可以实现90%以上T-SQL的功能(由于T-SQL是基于二维表的,所以LINQ的查询语法会比T-SQL更简单和灵活),但是由于智能感应的原因,select不能放在一开始就输入。

    95610

    C# 语言中Lambda(拉姆达) 表达式介绍

    Lambda 在基于方法的 LINQ 查询中用作标准查询运算符方法(如 Where)的参数。...可以将 Lambda 表达式转换为该类型的委托,因为该表达式也具有一个输入参数 (x),以及一个编译器可隐式转换为 int 类型的返回值。 (以下几节中将对类型推理进行详细讨论。)...有关查询语法与方法语法之间的差异的详细信息,请参阅 LINQ 中的查询语法和方法语法。...需要 lambda 的原因是无法使用查询语法调用 Sum 标准查询运算符。 查询首先根据学生的年级(在 GradeLevel 枚举中定义)对学生进行分组。 然后为每个组添加每个学生的总分。...Lambda 表达式并不只限于在 LINQ 查询中使用。 可以在需要委托值的任何地方(也就是在可以使用匿名方法的任何地方)使用这些表达式。

    8.1K40

    C#3.0新增功能09 LINQ 基础07 LINQ 中的查询语法和方法语法

    介绍性的语言集成查询 (LINQ) 文档中的大多数查询是使用 LINQ 声明性查询语法编写的。但是在编译代码时,查询语法必须转换为针对 .NET 公共语言运行时 (CLR) 的方法调用。...因此,即使在开始编写 LINQ查询时,熟悉如何在查询和查询表达式本身中使用方法语法也十分有用。...可以看到查询变量的类型在两种形式中是相同的:IEnumerable。 为了了解基于方法的查询,我们来仔细讨论它。...此内联表达式称为 lambda 表达式。 可采用匿名方法、泛型委托或表达式树的形式编写原本必须以更繁琐的形式编写的代码,这是一种便利的方式。...Lambda 的主体与查询语法中或任何其他 C# 表达式或语句中的表达式完全相同;它可以包含方法调用和其他复杂逻辑。 “返回值”就是表达式结果。 若要开始使用 LINQ,不必大量使用 lambda。

    3.9K20

    .NET3.5新特性,Lambda表达式

    Lambda表达式为编写匿名方法提供了更简明的函数式的句法,但结果却在编写LINQ查询表达式时变得极其有用,因为它们提供了一个非常紧凑的而且类安全的方式来编写可以当作参数来传递,在以后作运算的函数。...,它们既可以以基于IL的方法的形式被编译成代码代理(code delegate),或者也可以编译成一个表达式树(expression tree)对象,然后在运行时用来分析,转换或者优化表达式。...从Lambda表达式到代码代理 (Code Delegates) 上 面的Where扩展方法是个将Lambda表达式编译成代码代理(code delegate)的例子(意即它是编译成IL的,可以以代理的形式调用...而我希望的是,LINQ到SQL的ORM将我上面的Lambda过滤条件翻译成SQL表达式,然后在远程的数据库里进 行过滤性查询。...在LINQ到SQL的情形下,它会将这个Lambda过滤语句翻译成标准的关系SQL语句,来对数据库进行操作(从逻辑上来说,一个“SELECT * from Products where UnitPrice

    1.8K80

    表达式树

    在C#中,表达式树使在编译时表达式的结构和操作被保留下来,而不是像通常的.net代码那样被直接编译成IL。这使得你可以在运行时操作这些表达式或将它们转换成其他形式。...例如,你可以将一个表达式树转换为可重用的Lambda表达式,或者用于创建动态查询。或者,你可以遍历表达式树来读取和解析表达式的结构。...这种技术是.NET Framework中LINQ的基础,特别是在使用LINQ to SQL和LINQ to Entities时,因为它允许在运行时将LINQ查询表达式转换为SQL查询。...lambda表达式是匿名的,它们不具有特定的名称。 3. 表达式树:表达式树是一种特殊的数据结构,主要用于表示和处理代码以数据的形式。它们常常用于创建动态查询和解析、处理和执行命令模式。...表达式树可以用于创建LINQ查询:LINQ查询实际上就是表达式树。当你写一个LINQ查询时,编译器实际上是在后台创建一个表达式树。

    31620

    【深入浅出C#】章节 9: C#高级主题:LINQ查询和表达式

    数据转换:可以将一种数据形式转换为另一种,如将数据库结果转换为对象集合。...1.3 LINQ查询和表达式的基本工作原理 LINQ(Language Integrated Query)查询和表达式的基本工作原理如下: 查询表达式的转换: 当你使用LINQ查询语法时,编译器会将这些查询表达式转换为标准的扩展方法调用...查询翻译: 当查询被执行时,LINQ提供程序会将LINQ查询转换为特定数据源(如集合、数据库、XML等)的查询语言这意味着无论数据源是什么,LINQ查询的语法都是一致的。...查询的数据源 3.1 LINQ查询的数据源类型 IEnumerable:这是最常见的数据源类型,表示一个可枚举的集合,例如数组、列表、集等。...避免不必要的数据转换: 尽量避免在查询中频繁进行数据类型转换,以减少开销。 使用异步操作: 在适当的场景下,使用异步查询可以提高并发性能。

    2.3K61

    .NET深入解析LINQ框架(一:LINQ优雅的前奏)

    1】.LINQ简述 LINQ简称语言集成查询,设计的目的是为了解决在.NET平台上进行统一的数据查询。...这在LINQ中很常见,在你编写LINQ查询表达式时,你人为的去判断对象要返回的类型是很不现实的,但是由编译器来自动的根据语法规则进行分析就很理想化了。...由于LINQ依赖于扩展方法,进行链式查询,所以类型在编写时是无法确定的。后面的文章将详细的讲解到,这里先了解一下。...在.NET3.5框架的System.Linq.Expression命名空间中引入了以Expression抽象类为代表的一群用来表示表达式树的子对象集。...抽象类,而在抽象里重写了ToString方法,所以我们在看到的时候是ToString之后的字符串表示形式。

    1.9K31

    .NET面试题系列 - C# 3.0 LINQ的准备工作

    另外,它包含了你定义的类型成员,以及继承自object类型的若干方法(重写的Equals, 重写的GetHashCode, ToString等等)。...在LINQ中,我们可以使用匿名类型来装载查询返回的数据,尤其是最后使用Select或SelectMany等方法返回若干列时。...表达式树则是将表达式转换为树形结构,其中每个节点都是表达式。表达式树通常被用于转换为其他形式的代码。例如LINQ to SQL将表达式树转译为SQL。...Lambda为一希腊字母,无法翻译。希腊字母还有很多,例如阿尔法,贝塔等。...LINQ to SQL就是通过递归遍历表达式树,将LINQ语句转换为SQL查询的,这是委托所不能替代的。 不是所有的Lambda表达式都能转化成表达式树。

    1.2K30

    .NET深入解析LINQ框架(六:LINQ执行表达式)

    我们都是直接使用LINQ作为查询接口,VS在最后编译的时候负责对LINQ的语法进行解析并且翻译成对应的扩展方法调用。...我们忽视一个重要的环节,就是VS对LINQ进行解析翻译的时候是会执行LINQ表达式的,这点非常重要。...之前我一直以为VS只负责将LINQ的表达式翻译成等价的扩展方法调用,后来发现VS为了满足我们在前期无法确定对象条件的情况下进行Where字句的拼接,允许我们在编写LINQ语句的时候带有逻辑判断表达式在里面...由于LINQ是无法拆分开来进行组装的,必须一次写完才能通过编译。所以我们都在使用着查询扩展方法进行数据查询,这样的困境使我们无法看到LINQ的优雅,反而一直用不到。...总结:其实说了那么多目的只有一个,LINQ的解析过程并非只有一个“提供程序翻译成SQL”的过程,而是包括了两个阶段,四个过程的处理,LINQ的写法很多种,原理应该是差不多的,只要我们在写LINQ的时候综合考虑这几个处理过程

    1.3K10

    C#各版本新增加功能(系列文章)

    我们通常认为 C# 版本的杀手锏是查询表达式,也就是语言集成查询 (LINQ)。LINQ 的构造可以建立在更细微的视图检查表达式树、Lambda 表达式以及匿名类型的基础上。...LINQ 查询操作 C#3.0 新增功能09 LINQ 基础05 使用 LINQ 进行数据转换 C#3.0 新增功能09 LINQ 基础06 LINQ 查询操作中的类型关系 C#3.0 新增功能...概述 C#3.0 新增功能09 LINQ 标准查询运算符 02 查询表达式语法 C#3.0 新增功能09 LINQ 标准查询运算符 03 按执行方式的分类 C#3.0 新增功能09 LINQ...07 翻译(转换)表达式 C# 2.0 微软于2005年11月发布了.NET Framework 2.0,同时发布了Visual Studio 2005,同步对应的C#升级到了2.0版本。...迭代器 C#2.0 新增功能06 协变与逆变 C#2.0 新增功能07 getter/setter 单独可访问性 除现有功能以外的其他 C# 2.0 功能: 方法组转换(委托) 静态类 委托推断 C

    1.9K10

    C#3.0新增功能09 LINQ 标准查询运算符 04 运算

    Enumerable.ContainsQueryable.Contains 05 投影运算 投影是指将对象转换为一种新形式的操作,该形式通常只包含那些将随后使用的属性。...方法 方法名 说明 C# 查询表达式语法 详细信息 选择 投影基于转换函数的值。...然后,SelectMany() 串联这些可枚举序列,以创建一个大的序列。 下面两个插图演示了这两个方法的操作之间的概念性区别。...方法 下表列出了执行数据类型转换的标准查询运算符方法。 本表中名称以“As”开头的转换方法可更改源集合的静态类型,但不对其进行枚举。 名称以“To”开头的方法可枚举源集合,并将项放入相应的集合类型。...下图描绘了两个字符序列的串联操作。 ? 下面一节列出了执行串联的标准查询运算符方法。 方法 方法名 说明 C# 查询表达式语法 详细信息 Concat 连接两个序列以组成一个序列。 不适用。

    9.7K20

    Entity Framework 的一些性能建议

    ToList()的问题 其实EF很多时候的性能问题都是关系到查询执行时机的。我们通常的意图是,首先建立一个查询表达式,只是build,而不execute。...因为单纯声明一个linq表达式并不会立即执行SQL查询,然而一旦在后面加上ToList(),就会立即去执行。...大部分时候这两个接口在使用上的表现都是一致的,但如果你要做的是一个不确定的查询,意思是这个查询表达式不是一次性确定的,对于它的结果可能由别的类来选择到底select哪些东西,这时候就要用IQueryable...再紧接其后的Count就自然而然在内存里进行了。 如果要让代码尽量去生成LINQ to SQL,有个很简单的原则,就是尽量用LINQ、Lambda表达式,这样EF才可能帮我们翻译。...,LINQ to SQL就能准确翻译为“SELECT COUNT”了: SELECT [GroupBy1].

    1.7K30

    LinQ 查询表达式

    LinQ 查询表达式 發佈於 2019-02-20 最近的工作是对一个复杂数据库进行操作,模型类之间的关系很复杂。...操作方式使用了 LINQ,之前一直对 LINQ 的查询语法不太喜欢,这次使用之后,感觉比方法语法更容易接受,因此详细总结一下查询表达式的语法。 数据查询历来都表示为简单的字符串,没有编译时类型检查。...LINQ 最明显的”语言集成”部分就是查询表达式。 使用相同的基本查询表达式模式来查询和转换 SQL 数据库、ADO .NET 数据集、XML 文档以及 .NET 集合中的数据。...规则 查询表达式必须以 from 子句开头,且必须以 select 或 group 子句结尾。...查询表达式必须以 from 子句开头,它指定数据源以及范围变量,范围变量表示遍历源序列时,源序列中的每个连续元素。

    1.9K20

    .NET 7 中 LINQ 的疯狂性能提升

    LINQ 是 Language INtegrated Query 单词的首字母缩写,翻译过来是语言集成查询。它为查询跨各种数据源和格式的数据提供了一致的模型,所以叫集成查询。...由于这种查询并没有制造新的语言而只是在现有的语言基础上来实现,所以叫语言集成查询。 语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称。...借助 LINQ,查询成为了最高级的语言构造,就像类、方法和事件一样。 对于编写查询的开发者来说,LINQ 最明显的“语言集成”部分就是查询表达式。 查询表达式采用声明性查询语法编写而成。...使用查询语法,可以用最少的代码对数据源执行筛选、排序和分组操作。 可使用相同的基本查询表达式模式来查询和转换 SQL 数据库、ADO .NET 数据集、XML 文档和流以及 .NET 集合中的数据。...与 .NET 6 相比,.NET 7 中的某些 LINQ 方法具有一些惊人的性能改进。 看看下面的比率列,速度提升高达98%。

    94930

    LINQ&EF任我行(二)–LinQ to Object (转)

    (原创:灰灰虫的家http://hi.baidu.com/grayworm) LinQ to Objects是LinQ家庭的核心,其它的LinQ也使用了与LinQ to Objects相同的查询句法。...最终编译器都是把LinQ句法翻译成扩展方法的链式表达式,同时把扩展方法中的lambda表达式转换成匿名类中的匿名方法,然后再把查询表达式编译成MSIL。...LinQ to SQL、LinQ to DataSets、LinQ to Entities和LinQ to XML则不是把查询表达式转换成MSIL,而是把查询表达式树转换成相应的特定查询语言。...: var q = (from p in infos select p).Except(from m in temp select m); 九、转换操作符,用来改变集合的类型 (一)ToArray 把集合转换为数组形式...(二)ToList 把集合转换为泛型集合形式,不延迟 使用扩展方法: List g = infos.ToList(); 使用查询表达式语法: List g = (from p in

    2.4K30
    领券