C# 拓展方法(涉及Linq)

拓展方法

  • 定义一个扩展方法
  • 使用扩展方法
    • 例如
    • 再举个例子
    • 终极例子
  • 注意事项
  • 与Linq


C#中,扩展方法是一种特殊的静态方法,允许开发者向现有类型“添加”新的方法,而无需修改该类型的源代码或创建新的派生类型。这种机制提供了一种更为灵活的方式来扩展已有的类或结构的功能。

C# 中的扩展方法是一种特殊的静态方法,它允许你为现有类型添加新的方法,而不需要修改原始类型。扩展方法通常用于为那些你无法修改的类型添加功能,比如 .NET Framework 中的类型。


扩展方法的定义必须在一个静态类中,并且方法的第一个参数必须使用 this 关键字,这个
参数指定了扩展方法所作用的类型


定义一个扩展方法

要定义一个扩展方法,需要遵循以下规则:

扩展方法必须在静态类中定义。
扩展方法的第一个参数要使用 this 关键字,并且这个参数指定了方法将扩展哪个类型。
第一个参数之后的参数是扩展方法所需要的其他参数。
下面是一个简单的扩展方法的例子,这个方法为 int 类型添加了一个名为 Square 的方法,用于计算整数的平方:

public static class IntegerExtensions
{// 这是一个扩展方法,它扩展了 int 类型public static int Square(this int num){return num * num;}
}

使用扩展方法

一旦定义了扩展方法,就可以像使用实例方法一样来使用它。

例如

using System;namespace ExtensionMethods
{class Program{static void Main(string[] args){int number = 5;int square = number.Square(); // 调用扩展方法Console.WriteLine($"The square of {number} is {square}");}}public static class IntegerExtensions{public static int Square(this int num){return num * num;}}
}

在这个例子中,我们不需要修改 int 类型的定义,就可以直接调用 Square 方法。


再举个例子

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace forCode {class Program {static void Main(string[] args) {double a = 2;int b = a.Square();Console.WriteLine($"b = {b}");Console.ReadKey();}}public static class aa {public static int Square(this double num) {return Convert.ToInt32(Math.Pow(num, 2.0));}}}

上述例子是double的拓展,一个double变量平方后转为int


终极例子

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace forCode {class Program {static void Main(string[] args) {MyNumber m = new MyNumber();m.a = 1;m.AddSome(3);Console.WriteLine($"m.a = {m.a}");Console.ReadKey();}}public class MyNumber {public int a;} public static class MyExTention {public static int Square(this double num) {return Convert.ToInt32(Math.Pow(num, 2.0));}public static void AddSome(this MyNumber myNumber, int num) {myNumber.a += num;}}}

为自定义的类添加扩展方法

注意事项

扩展方法不能访问它们所扩展的类型中的私有成员。
如果扩展方法与现有方法冲突,那么扩展方法将不会被调用。
扩展方法是一种语法糖,编译器会将它们转换为静态方法的调用。
通过使用扩展方法,开发者可以更加方便地对现有类型进行功能增强,同时保持代码的整洁和可维护性。

与Linq

Where就是一种扩展方法
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenGL给定直线起点和终点不同的颜色,使用中点Bresenham画线

用鼠标左键按下确定直线起点&#xff0c;鼠标左键抬起确定直线终点。放一部分代码。 // 中点Bresenham算法.cpp : 定义控制台应用程序的入口点。 //#include "stdafx.h" #include <GL/glut.h> #include <iostream> #include <cmath>int windowWidt…

Linux更改系统中的root密码

Linux里面的root密码忘记了怎么办&#xff1f; 1 更改系统中的 root 密码 &#xff08;1&#xff09;键盘 CtrlAltT 快捷键打开终端。 &#xff08;2&#xff09;在终端窗口中输入以下代码&#xff1a; sudo passwd root &#xff08;3&#xff09;输入锁屏密码 &#xf…

解决本地环境正常但Linux服务器上Gson日期解析失败的问题

问题背景 在软件开发过程中&#xff0c;本地环境与服务器环境之间的差异可能导致意外的运行时错误。本文将探讨一个常见的问题&#xff1a;在本地环境中使用 Gson 库解析 JSON 数据时日期字段正常解析&#xff0c;但部署到 Linux 服务器上时却出现 JsonSyntaxException 错误。…

常见的授权场景及其实现方法

在微服务架构中处理授权时&#xff0c;通常考虑多种场景来保证系统的安全性和灵活性。这些场景涵盖了从简单的API权限验证到复杂的基于策略的访问控制。下面&#xff0c;我将详细介绍几种常见的授权场景及其实现方法。 文章目录 1. 简单的权限验证实现方法&#xff1a; 2. 细粒…

从0开始学统计-战斗机保护和代表性抽样

1.什么是抽样研究&#xff1f;为什么要做抽样研究&#xff1f; 抽样研究是一种研究方法&#xff0c;它涉及从整体人群或群体中选取一部分样本来代表整体&#xff0c;以进行研究和推断。在抽样研究中&#xff0c;研究者从总体中选择一个相对较小的样本&#xff0c;通过对这个样…

2024-05学习笔记

最近的学习大多都是和mysql的索引相关的 1.mvcc mvcc是不需要手动配置&#xff0c;是mysql的一个机制 在事务开启时&#xff0c;对涉及到的数据加一个隐藏列&#xff0c;隐藏列对应的值&#xff0c;就是事务id 如果当前是修改操作&#xff0c;就copy一份原来的数据到新的一行…

Topk问题以及二叉树的三种层序遍历和基本操作

一、Topk问题 1、问题描述 TOP-K问题&#xff1a;即求数据结合中前K个最大的元素或者最小的元素&#xff0c;一般情况下数据量都比较大。 比如&#xff1a;专业前10名、世界500强、富豪榜、游戏中前100的活跃玩家等。 2、思路 对于Top-K问题&#xff0c;能想到的最简单直接的…

【npm如何使用以及常用的包npm包的用法】

npm&#xff08;Node Package Manager&#xff09;是Node.js的包管理工具&#xff0c;用于安装、卸载、更新和管理Node.js应用程序的依赖项。以下是npm的基本使用方法和一些常用npm包的用法&#xff1a; 一、npm的基本使用方法 安装npm&#xff1a;npm通常与Node.js一起安装。…

618快到了,送大家一款自动化脚本工具,一起薅羊毛

前言 一年一次的618活动来了&#xff0c;大家做好准备了&#xff0c;奇谈君为大家准备好用的618神器&#xff0c;解放双手&#xff0c;简单操作就可以把红包拿到手。 京淘自动助手 首次使用前需要进行设置 将手机的无障碍权限和悬浮窗权限打开 设置完成后&#xff0c;可以把…

什么是健康信息卡

健康档案信息卡是交由居民本人保管的个人健康信息卡片。 其内容包括&#xff1a;居民个人主要基本信息、健康档案编码、患有的重要疾病、过敏史以及紧急情况下的联系人及联系方式&#xff0c;还有所属基层医疗机构的责任医生、护士及联系电话等。它主要用于居民在复诊、转诊或接…

Android 14.0 系统多个播放器app时,设置默认播放器

1.概述 在14.0的系统产品开发中,对于在系统中有多个播放器的时候,这时候如果调用代码打开播放器,会出现多个播放器列表让用户选择启动哪个播放器,所以产品开发需求需要设置默认播放器,当打开播放器的时候,就直接打开播放器就可以了,所以就需要了解查询播放器列表流程,然…

JAVA面试题大全(十二)

1、RabbitMQ 的使用场景有哪些&#xff1f; 跨系统的异步通信&#xff0c;所有需要异步交互的地方都可以使消息队列多个应用之间的耦合应用内的同步变异步消息驱动的架构跨局域网&#xff0c;甚至跨城市的通讯 2、RabbitMQ有哪些重要的角色&#xff1f; RabbitMQ的重要角色…

UTC与GPS时间转换-[week, sow]

UTC与GPS时间转换-[week, sow] utc2gpsgps2utc测试参考 Ref: Global Positioning System utc2gps matlab源码 function res utc2gps(utc_t, weekStart)%% parameterssec_day 86400;sec_week 604800;leapsec 18; % 默认周一为一周的开始if nargin < 2weekStart d…

算法打卡 Day10(栈与队列)-用栈实现队列 + 用队列实现栈

今天开始进入栈与队列啦&#xff01; 文章目录 栈与队列理论基础栈 Leetcode 232-用栈实现队列题目描述解题思路 Leetcode 225-用队列实现栈题目描述解题思路 首先我们来学习一下栈与队列的基础知识~ 栈与队列理论基础 栈与队列的区别是&#xff1a;栈是先进后出&#xff0c…

Python | Leetcode Python题解之第111题二叉树的最小深度

题目&#xff1a; 题解&#xff1a; class Solution:def minDepth(self, root: TreeNode) -> int:if not root:return 0que collections.deque([(root, 1)])while que:node, depth que.popleft()if not node.left and not node.right:return depthif node.left:que.appen…

1.4 视频标准组织 - ITU

1.4 视频标准组织 - ITU 关于 ITU 国际电信联盟&#xff08;International Telecommunication Union&#xff0c;简称 ITU&#xff09;是一个国际组织&#xff0c;主要负责确立国际无线电和电信的管理制度和标准。 关于 ITU-R 国际电信联盟无线电通信部门&#xff08;ITU R…

cnVcXsrv 21.1.13.1—VcXsrv 21.1.13中文版本简单说明~~

对于VcXsrv的使用目的和用途相信大家都很了解。前不久VcXsrv做了更新&#xff0c;并且将项目托管到github上了。链接如下&#xff1a; VcXsrv: Windows X-server based on the xorg git sourceshttps://github.com/marchaesen/vcxsrv也可以简单查看如下链接&#xff1a; VcXs…

9数据通信名词解释2

奈氏准则 在理想低通&#xff08;无噪声&#xff0c;带宽受限&#xff09;条件下&#xff0c;为了避免码间串扰&#xff0c;极限码元传输速率为2WBaud&#xff0c;W是信道带宽&#xff0c;单位是赫兹 结论&#xff1a; ①在任何信道中&#xff0c;码元的传输速率是有上限的&…

.Net Core WebAPI参数的传递方式

Controller继承自ControllerBase&#xff0c;只不过增加了视图相关的方法&#xff0c;一般mvc项目选用Controller而Web API项目选择ControllerBase即可。 给服务器传递参数的时候&#xff0c;有URL、QueryString、请求报文体3种方式 请求路径/Student/GetAll/school/MIT/class…

在matlab里面计算一组给定参数的方程的解

如&#xff1a; k (1:1024); f (x)(1-x-k.*x.^2); 在这段代码给出了一组函数&#xff0c;若需要计算f0&#xff0c;可以通过自带的函数实现&#xff1a; x0 zeros(length(k),1); options optimoptions(fsolve,Display,none,TolX,tol,TolFun,tol); tic for ik 1:length…