C#核心知识回顾——2.拓展方法、运算符重载、分部类、里氏替换

news2025/1/24 8:27:30
1.拓展方法

为现有非静态变量类型添加新方法

1.提升程序拓展性
2.不需要再对象中重新写方法
3.不需要继承来添加方法
4.为别人封装的类型写额外的方法


特点:
1.一定是写在静态类中
2.一定是个静态函数
3.第一个参数为拓展目标
4.第一个参数用this修饰

/// <summary>
/// 拓展方法必须定义在非泛型的静态类中
/// </summary>
static class Person
{
    //为int拓展成员方法
    //成员方法是需要实例化才能用
    //value代表使用该方法的实例化对象
    public static void Peak(this int value)
    {
        Debug.Log("class "+ value);
    }
}

class GetPeson
{
    void Start()
    {
        int i = 0;
        i.Peak();
        //输出内容:class 0
    }
}

为自定义类型拓展方法:

static class Person
{
    /// <summary>
    /// 如果拓展方法跟原类方法名字一致且参数一致,则拓展方法无效
    /// </summary>
    /// 为自定义类型拓展方法
    /// public static void Fun2(this Test t,sting str)添加参数形式

    public static void Fun2(this Test t)
    {
        Debug.Log("test "+ t);
    }
}
/// <summary>
/// 自定义类型
/// </summary>
class Test
{
    public int x = 10; 

    public void Fun1()
    {
        Debug.Log("123");
    }

}
class GetPeson
{
    void Start()
    {
        Test t = new Test();
        t.Fun2();
        //输出内容:test 10
    }
}

2.运算符重载:

让自定义类和结构体能够使用运算符
使用关键字operator

1.一定是一个公共的静态方法
2.返回值写在operator前
3.逻辑处理自定义

作用
让自定义类和结构体对象可以进行运算

注意!!:
1.条件运算符需要成对实现
2.一个符号可以多个重载
3.不能使用ref和out

/// <summary>
/// 运算符重载
/// </summary>
public class Point 
{
    public int x;
    public int y;

    //public static 返回类型 operator 运算符(参数列表)
    public static Point operator +(Point p1, Point p2)
    {
        Point p = new Point();
        p.x = p1.x + p2.x;
        p.y = p1.y + p2.y;
        return p;
    }
    public static Point operator +(Point p1, int value)
    {
        Point p = new Point();
        p.x = p1.x + value;
        p.y = p1.y + value;
        return p;
    }
}


public class GetInfo : MonoBehaviour
{
    private void Start()
    {
        Point p1 = new Point();
        p1.x = 10;
        p1.y = 20;
        Point p2 = new Point();
        p2.x = 10;
        p2.y = 20;

        Point point = new Point();
        point = p1 + p2;

        Point p = point;
        //注意参数顺序
        p = p1 + 2;
    }
}

可以使用运算符重载的运算符:

算术运算符:+  -  *  /  %  ++  --     (++ -- 一个参数)

逻辑运算符:|  一个参数

位运算符: |  &  ^异或  ~取反  <<左移  >>右移   (~ 一个参数,左右移两个参数其中一个是int表示                                                                                                                                      移动多少位)

条件运算符:>  <  <=  >=  ==  !=   (条件运算符必须成对使用!)

不可重载的运算符:

逻辑与(&&)逻辑或(||)
索引符口  [ ]
强转运算符()

特殊运算符:
点.   三目运算符?:   赋值符号=

3.内部类、分部类

内部类:类里套类,被嵌套的类使用时需要通过嵌套类点出来,同时访问修饰符起决定因素

public class Point 
{    
    public class Body
    {
        public float mass;
    } 
}
public class GetInfo : MonoBehaviour
{
    private void Start()
    {
       Point.Body b = new Point.Body();
    }
}

分部类:一个类分开写,可以写在不同的脚本,用关键字标识,同时访问修饰符要一致。

partial class Point 
{
    public bool get;
    public int i;

    /// <summary>
    /// 分部方法:关键字+void 参数不能用out,不能有访问修饰
    /// </summary>
    partial void Speak();
}
partial class Point
{
    public string name;

    partial void Speak()
    {
        //分部方法实现
    }
}
public class GetInfo : MonoBehaviour
{
    private void Start()
    {
        Point p = new Point();
        p.name = name;
        p.get = false;
    }
}

4.里氏替换原则:

概念:父类容器装子类对象
作用:方便进行对象的存储和管理
使用:is和as
is用于判断
as用于转换
注意:不能用子类容器装父类对象

public class Point 
{
    public bool get;
    public int i;

}
/// <summary>
/// 子类
/// </summary>
public class Body : Point
{
    public void TestInfo(){}
}
/// <summary>
/// 子类
/// </summary>
public class Arm : Point
{
    public void GetInfo() { }
}
public class GetInfo : MonoBehaviour
{
    private void Start()
    {
        Point p = new Body();
        Point p2 = new Arm();
        Point[] p3 = new Point[] {new Body(),new Arm()};

        ///is关键字,用于判断子类,进一步调用子类内容
        if(p is Body)
        {
            ///as 关键字  将p指定为对应子类,就可以调用子类方法
            (p as Body).TestInfo();
        }
        //通过遍历判断子类类型。
        for (int i = 0; i < p3.Length; i++)
        {            
            if (p3[i] is Arm) 
            {
                (p3[i] as Arm).GetInfo();
            }
            else if (p3[i] is Body)
            {
                (p3[i] as Body).TestInfo();
            }
        }
    }
}

 练习1:

public class Monster 
{
}
public class Boss : Monster
{
    public void AtackBoss()
    {
        Debug.Log("大招");
    }
    
}
public class Goblin : Monster
{
    public void AtackGoblin()
    {
        Debug.Log("小怪");
    }
}

public class GetInfo : MonoBehaviour
{
    private void Start()
    {
        Monster[] monster = new Monster[10];

        for (int i = 0; i < 10; i++)
        {
            int value = Random.Range(0, 2);
            if(value == 0) {
                monster[i] = new Boss();
            }
            else
            {
                monster[i] = new Goblin();
            }
        }

        for (int i = 0; i < monster.Length; i++)
        {
            if (monster[i] is Boss)
            {
                (monster[i] as Boss).AtackBoss();
            }
            else if (monster[i] is Goblin)
            {
                (monster[i] as Goblin).AtackGoblin();
            }
        }
    }
}

练习2:

public class Monster 
{
}
public class Gun : Monster
{
    public void Atack()
    {
        Debug.Log("枪");
    }    
}
public class Bi : Monster
{
    public void Atack()
    {
        Debug.Log("匕首");
    }
}
public class Chong : Monster
{
    public void Atack()
    {
        Debug.Log("冲锋");
    }
}
public class San : Monster
{
    public void Atack()
    {
        Debug.Log("散弹");
    }
}
public class GetInfo : MonoBehaviour
{
    Monster[] monster = new Monster[] {new Bi(), new Gun(), new Chong(), new San() };
    private void Start()
    {
        (monster[0] as Bi).Atack();
    }
    private void Update()
    {
        ///模拟切换武器
        if (Input.GetKeyDown(KeyCode.A))
        {
           ChangeWuQi(Random.Range(0, monster.Length-1));
        }
    }
    void ChangeWuQi(int i)
    {
        if (monster[i] is Bi)
        {
            (monster[i] as Bi).Atack();
        }
        else if (monster[i] is Gun)
        {
            (monster[i] as Gun).Atack();
        }
        else if (monster[i] is Chong)
        {
            (monster[i] as Chong).Atack();
        }
        else if (monster[i] is San)
        {
            (monster[i] as San).Atack();
        }
    }
}

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

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

相关文章

element table表格支持添加编辑校验

实现效果&#xff1a; 将table表格与form表单结合使用 &#xff08;用el-form外层包裹el-table结合rules进行校验&#xff09; 代码实现 <template><div><el-card class"box-card" shadow"never"><div><el-buttonsize"m…

E8-事关明细表里的控件事件绑定、日期的计算、明细表的求和等问题的处理办法

起因 下面的讲述的事情是从开发出差申请流程开始的。涉及的知识点偏多&#xff0c;且得容我慢慢梳理出来。以下篇幅可能会有点儿长&#xff0c;但内容我会争取写得精彩的。 图1 发起表单样式如图1&#xff0c;我想实现的是当修改出发日期或结束日期的时候&#xff0c;自动计算…

并发-synchronized详解

JDK1.6之前的synchronized关键字一来就直接给对象加了一把重量级锁&#xff0c;频繁地在用户态和内核态之间切换&#xff0c;导致性能非常低。为了弥补synchronized的不足&#xff0c;大佬doug lee写了一个AQS框架&#xff0c;用Java语言实现了ReentrantLock。然后在JDK1.6之后…

电脑文件夹怎么设置密码?3个方法为文件加密!

我的电脑里存了很多重要的文件夹&#xff0c;为了防止信息的泄露&#xff0c;我想把这些文件夹都设置密码。但是不知道具体应该如何操作。请求大家的帮助&#xff01; 我们平常在使用电脑时&#xff0c;可能会将很多重要的文件保存在电脑中。如果不想让别人看到我们这些重要的文…

JMeter安装RabbitMQ测试插件

目录 前言&#xff1a; 具体实现步骤&#xff1a; 1、ant环境搭建 2、AMQP源码下载 3、拷贝JMeter_core.jar包到JMeter-Rabbit-AMQP插件根目录下 4、修改AMQP插件的配置文件 5、打包 6、RabbitMQ客户端插件下载 7、完成以上&#xff0c;重启JMeter创建线程组就可以看到…

智能小家电如何升级Type-C接口充电?

目前市面上智能小家电充电接口还是USB Micor&#xff0c;AC&#xff0c;DC接口等&#xff0c;今年随着欧盟的一纸令下&#xff0c;22年12月24日&#xff0c;欧洲理事会最终批准了“在欧盟范围内统一充电器接口”的法案。这意味着到2024年&#xff0c;usb type-c接口将成为一系列…

openknx初编译

knx协议出来也是很长时间了&#xff0c;但国内相关开发的文章很少&#xff0c;比起zigbee,lora这些网上一搜一大零的&#xff0c;显得可怜。因为公司以后可能会开发knx产品&#xff0c;所以对国外的openknx自已研究了一下。 https://github.com/thelsing/knx 这个就是openknx项…

Openlayers实战,Openlayers调整地图可视范围到多个点组成的多边形边界,可视范围缩放到多个点的中心点

专栏目录: OpenLayers入门教程汇总目录 前言 本片文章详细讲解如何使用Openlayers调整地图可视范围到多个点组成的多边形边界。 也即Openlayers根据多个点坐标生成一个矩形可视范围,并判断当前传入的矩形可视范围是否在当前可视范围内。如果在当前可视范围内,则调整地图中…

latex中两种图并排放,而且各自有小标题caption

\begin{figure*}[htbp] \centering #小标题 \subfigure[Case study in terms of interpretability on dataset HDep3.]{ \begin{minipage}[t]{0.37\linewidth} %linewidth小于0.5 \centering \includegraphics[scale0.2]{figures/hdep3d.png} #大小主要调节scale. %\caption{fi…

Blazor前后端框架Known-V1.2.1

V1.2.1 Known是基于C#和Blazor开发的前后端分离快速开发框架&#xff0c;开箱即用&#xff0c;跨平台&#xff0c;一处代码&#xff0c;多处运行。 概述 基于C#和Blazor实现的快速开发框架&#xff0c;前后端分离&#xff0c;开箱即用。跨平台&#xff0c;单页应用&#xff…

耳挂式骨传导耳机哪个牌子好,分享几个品牌的骨传导耳机

骨传导耳机就是利用震动来传递声音的耳机&#xff0c;在运动时佩戴骨传导耳机&#xff0c;可以听歌也能听周围的声音&#xff0c;提高了运动时的安全性。目前市面上的骨传导耳机也是琳琅满目。今天就来给大家分享下目前市面上比较常见的几款骨传导耳机。希望对正在选购骨传导耳…

Linux v4l2框架分析

1. 概述 V4L2(Video for Linux 2)&#xff1a;Linux内核中关于视频设备驱动的框架&#xff0c;对上向应用层提供统一的接口&#xff0c;对下支持各类复杂硬件的灵活扩展&#xff1b; V4L2框架&#xff0c;主要包括v4l2-core、meida framework、videobuf2等模块&#xff0c;这也…

120.【ElastiSearch】

ElasticSearch-初级 (一)、什么是ElasticSearch(库、表、记录)1.ElasticSearch是什么2.ElasticSearch学习路线3.聊聊Doug Cutting4.Lucene 和 ElasticSearch的关系: (二)、ElasticSearch概述1.基本概述2.百度搜索关键字思考3.目前都有哪些公司在用ElasticSearch技术 (三)、ES和…

检验样本是否服从泊松分布

本文以一个订单数据为例&#xff0c;研究顾客购买次数的分布规律&#xff0c;尝试从中估计总体的分布&#xff0c;以对后续的订单数据进行预测或进行业绩的对比。 # 环境准备 import numpy as np import pandas as pd import scipy.stats as stats import matplotlib.pyplot a…

Nginx(3)nginx的Rewrite功能

nginx跨域 Rewrite功能配置Rewrite的相关命令Rewrite的案例域名跳转域名镜像独立域名目录自动添加/合并目录防盗链 Rewrite功能配置 Rewrite是Nginx服务器提供的一个重要基本功能&#xff0c;是Web服务器产品中几乎必备的功能。主要的作用是用来实现URL的重写。 注意:Nginx服…

AI生成图片检测器接口,应用于内容审核、虚拟现实应用和促进艺术及设计领域创新等场景

【检测率99.0%以上】可以快速准确地判断一张图片是否为AI生成&#xff0c;减少人工审核的工作量&#xff0c;提高工作效率、降低运营成本&#xff0c;帮助人们更好地管理和利用数字图像资源。广泛应用于内容审核、虚拟现实应用和促进艺术及设计领域创新等场景。 一、效果展示 …

Unity学习笔记--EventSystem事件系统在使用上需要注意的地方(很基础,但是很多人会忘记!!!)

目录 前言代码Unity 场景配置运行报错分析解决办法拓展&#xff08;预告&#xff09; 前言 之前有写过一篇关于事件系统实现以及使用的文章 Unity学习笔记–C#事件系统的实现与应用 最近在使用的时候遇到了一些问题&#xff0c;所以在此记录下&#xff0c;也为看到这篇文章的人…

魏副业而战:视频带货借助热点,这个账号月赚20w+

我是魏哥&#xff0c;与其在家躺平&#xff0c;不如魏副业而战&#xff01; 最近魏哥一直在研究短视频&#xff0c;每天刷刷抖音&#xff0c;经常刷到高考相关的视频。 本来高考跟我没关&#xff0c;毕竟孩子还小&#xff0c;但是刷得多了&#xff0c;魏哥发现有情况。 像这个…

oneAPI人工智能分析工具包实现图像处理

文章目录 一、oneAPI的介绍二、oneAPI实现图像处理环境配置加载预训练模型和网络创建IECore对象和设备插件准备输入数据执行推理总结 一、oneAPI的介绍 oneAPI是一个由英特尔&#xff08;Intel&#xff09;主导的、面向异构计算的开放标准和平台。它旨在简化和加速跨多种硬件架…

体验攻略 | 新时代的用研人,没有它不行

用户研究&#xff08;以下简称“用研”&#xff09;是随着互联网兴起和发展、从体验设计领域进一步分化出来的岗位。在互联网公司&#xff0c;用研岗位更多以用户体验为导向&#xff0c;主要工作为洞察用户的需求、行为和动机&#xff0c;为产品开发和服务设计提供指导性意见。…