C#入门基础三

封装:简化用户接口,隐藏实现细节。 get{return 属性值;} set{属性值 = value;}

继承:子类继承父类所有非私有成员。继承具有传递性,单根性。 隐式继承:用引号(:)实现。 显示继承:关键字(:base)实现。

显示继承与隐式继承的区别: 简单来说就是说 如果继承的一堆接口中 有2个或者2个以上的接口有同名的属性/方法,而它们又是不同的功能的话,你就应该显示继承接口 反过来 随意(一般用隐式,因为可以偷懒) 如果你很犹豫应该用哪一种 而又必须保证不会出问题 直接使用显式

方法的重写:重写必须发生在继承基础之上。可用关键字virtual设置为虚方法,在用override重写。或用关键字new重写。 virtual关键字使用语法:[访问修饰符]virtual[返回类型]方法名称(参数列表) 重写可以重写  虚方法、  已经重写过的方法  、抽象方法

抽象类与抽象方法: 抽象类:不能被实例化的类称为抽象类,抽象类是派生类的基础。抽象类只能被普通类继承并实现。关键字abstract抽象类   不能实例化、  能被普通类继承并实现 定义语法:abstract class<类名>

抽象方法:抽象方法没有方法体,只能定义在抽象类中。

抽象类可以不写抽象方法,但抽象方法一定得放在抽象类中。

接口: 定义语法:[访问修饰符]interface<接口名> 关键字:interface 定义接口名一般都是以"i"开头,例:iname 接口主体不能写带方法体的方法;不能写访问修饰符;不能写属性。

接口与抽象类的区别:                     抽象类                        接口

用abstract定义               用interface定义

只能继承一个类               可以实现多个接口

非抽象派生类必须实现抽象方法          实现接口的类必须实现所有成员 不同点

需要override实现抽象方法                   直接实现

不能被实例化 相同点  包含为实现的方法  派生类(子类)必须实现未实现的方法

===============================================================================================

索引器:关键字==this 【C#通过提供索引器,可以象处理数组一样处理对象。特别是属性,每一个元素都以一个get或set方法存在。 作用:索引器可以使用户像访问数组一样访问类成员。

语法:     [访问修饰符]数据类型 this[数据类型 标识符]

{               get{}               set{}      }

例:namespace syq {

class Program

{         static void Main(string[] args)

{             Clas cls = new Clas(3);

Student stu = null;             //创建三个学生信息,并向班级中加载学生信息

for (int i = 0; i < 3; i++)             {

stu = new Student("蓝天" + (i + 1));

cls[i] = stu;             }

//按索引进行检索并显示结果

Console.WriteLine(cls[2].Name);

//按姓名进行检索并显示结果

Console.WriteLine(cls["蓝天1"].Name);         }     }

class Class3     {     }     /// <summary>     /// 学生信息类     /// </summary>     public class Student

{         private string _name;         public Student(string name)         {             this._name = name;         }         public string Name         {             get { return this._name; }         }     }     /// <summary>     /// 班级类,即学生的集合     /// </summary>     public class Clas     {         //用于存放学生信息的数组         private Student[] _students;         //用于创建班级时必须指定该班级的大小         public Clas(int count)         {             this._students = new Student[count];         }         //传递的索引用于对照片数组进行检索         public Student this[int index]         {             get {                     if (index < 0 || index >= this._students.Length)//验证索引范围                     {                         Console.WriteLine("索引无效");                         return null;                     }                     return _students[index];//对于有效索引,返回请求的学生信息                 }             set {                     if (index < 0 || index >= this._students.Length)//验证索引范围                     {                         Console.WriteLine("索引无效");                         return;                     }                     //对于有效索引,像数组加载新的学生信息                     this._students[index] = value;                 }         }         //这里定义的按学生姓名检索照片的索引是只读的         public Student this[string name]         {             get             {                 //循环遍历数组中的所有学生信息                 foreach (Student s in this._students)                 {                     if (s.Name == name)//将学生的姓名与索引器参数进行比较                         return s;                 }                 Console.WriteLine("未找到");                 return null;             }

}     } }

委托:关键字==delegate 【 委托包含对方法而不是方法名称的引用。使用委托可以在运行时动态设定要调用的方法。委托可以理解为是一个指向方法的指针,它是类型安全的。 它具有两大特点:面向对象,类型安全和可靠的。

委托若要执行某一方法,则返回类型与参数列表必须和方法一致。 语法:[访问修饰符]delegate 返回类型 委托名(参数列表);

例:namespace weituo {     class Program     {         static void Main(string[] args)         {             pengge pp = new pengge();             pp.chi();         }         //定义委托。委托若执行方法,返回类型与参数列表必须和方法相同         public delegate string pgg(int money);         //委托者         public class pengge         {             public void chi()             {                 zhaoshuai mm = new zhaoshuai();   //实例化委托                 pgg cc = new pgg(mm.mai2);//调用委托                 Console.WriteLine(cc(2));             }         }         //执行者         public class zhaoshuai         {             public string mai()             {                 return "烧饼";             }             public string mai2(int money)             {                 return "又买烧饼?!!!!";             }         }     } } 】

事件:关键字==event 【 事件是一种特殊的委托。

语法:[访问修饰符]event 委托名 事件名;

例:namespace shijian {

class Program     {

static void Main(string[] args)         {             pengge pgg = new pengge();             pgg.chi();         }         //定义委托         public delegate void dlgt();         public class pengge         {             //定义事件             public event dlgt myevent;             public void chi()             {             zhaoshuai zs = new zhaoshuai();             //订阅事件             myevent += new dlgt(zs.maifan);             myevent += new dlgt(zs.toudu);             myevent += new dlgt(si);             //触发事件             myevent();             }             public void si()             {                 Console.WriteLine("原来是这样");             }         }         public class zhaoshuai         {             public void maifan()             {                 Console.WriteLine("又买饭?!");             }             public void toudu()             {                 Console.WriteLine("鹏哥威武!毒死你!");             }         }     } } 】

事件与委托的区别: 事件就是一个狭义的委托,也就是事件是一个用于事件驱动模型的专用委托.

通俗的讲,委托你可以在客户代码中直接调用委托来激发委托指向的函数,而事件不可以,事件的触发只能由服务代码自己触发

也就是说在你的代码里委托你不但可以安排谁是它的调用函数,还可以直接调用它,而事件不能直接调用,只能通过某些操作触发

时间: 2024-08-03 20:02:00

C#入门基础三的相关文章

shell 入门基础三

    linux shell 编程 1什么是bash shell 变量 shell变量可分为两类: 局部变量和环境变量. 局部变量只在创建它们的shell中可用.而环境变量则可以在创建它们的shell及其派生出来的任意子进程中使用.有些变量是用户创建的,其他的则是专用shell变量.变量名必须以字母或下划线字符开头.其余的字符可以是字母.数字(0~9)或下划线字符.任何其他的字符都标志着变量名的终止.名字是大小写敏感的.给变量赋值时,等号周围不能有任何空白符.为了给变量赋空值,可以在等号后跟一

mybatis入门基础(三)----SqlMapConfig.xml全局配置文件解析

阅读目录 一:SqlMapConfig.xml配置文件的内容和配置顺序如下 二:properties属性 三:settings全局参数配置 四:typeAiases(别名)--重点掌握 五:typeHandlers(类型处理器) 六:mappers(映射配置) 回到顶部 一:SqlMapConfig.xml配置文件的内容和配置顺序如下 properties(属性) settings(全局配置参数) typeAiases(类型别名) typeHandlers(类型处理器) objectFactor

Objective-C 快速入门--基础(三)

1.OC有几种方式创建字符串对象?如:如何创建一个字符串对象:@“Baby”. OC中有3种方式创建字符串对象: 示例:main.m文件中: 控制台输出: 2.OC中如何获取字符串的长度? OC中获取字符串的长度要用“length”; 示例:mian.m文件中: 控制台输出: 3.判断字符串是否以指定字符串开始或结束:用代码举例. 示例:main.m文件中: 控制台输出: 4.查找某个字符串在另一个字符串中的范围. 如查找在字符串@”爱你”在@”我爱你们”中的范围. 示例:main.m文件中:

Reactjs 入门基础(三)

State 和 Props以下实例演示了如何在应用中组合使用 state 和 props .我们可以在父组件中设置 state, 并通过在子组件上使用 props 将其传递到子组件上.在 render 函数中, 我们设置 name 和 site 来获取父组件传递过来的数据. Props 验证 Props 验证使用 propTypes,它可以保证我们的应用组件被正确使用,React.PropTypes 提供很多验证器 (validator) 来验证传入数据是否有效.当向 props 传入无效数据时

2015.4.10-C#入门基础(三)

今天,我们聊一聊一些基本问题: 1.修饰符有哪些?有什么区别呢? 首先大家想到的应该是 public:特点是所属类的成员和非所属类的成员都可以访问 private:只有所属类的成员才可以访问 protected:所属类或派生自所属类的类型可以访问 internal: 当前程序集可以访问,也就是 一个程序下的几个类 那么 还有一个就是       protected internal:不同的是,只有当前程序集他的子类 才可以访问 2.方法是什么呢,怎么用的呢? 方法就是由程序语句组成的,调用方法名

Python入门基础学习 三

Python入门基础学习 三 数据类型 Python区分整型和浮点型依靠的是小数点,有小数点就是浮点型. e记法:e就是10的意思,是一种科学的计数法,15000=1.5e4 布尔类型是一种特殊的整形,true就相当于1,false相当于0,可以用来计算 类型转换 转换:整数:int();字符串:str();浮点数:float() 转换例子:(图9) 如果用内置函数当变量名,比如str=123,一旦被赋值,再使用这个函数会被报错. type()函数可以明确告诉我们变量类型. isinstance

ReactJS入门基础

渲染这俩字可能在很多地方都见过.但可能不太理解是啥意思. 那么首先我们来理解一下渲染. 渲染 我觉得这样理解比较通俗. 我们做一个汽车,开始是没有喷漆的(没有css) 只是些框框架架(HTML标签).那么网页加载就是首先加载完HTML元素,其次是css,css去遍历渲染每个对应元素的样式让其看起来就是我们所想看到的效果一样.不同浏览器的渲染方式不一样,渲染机制也不一样. 简单来将一个完整的HTML页面渲染完成是有2个东西的.一个HTML元素加载完成,一个是CSS样式加载完成.其次才是JS,如果J

【转】Gulp入门基础教程

Gulp入门基础教程 原文在此 前言最近流行前端构建工具,苦于之前使用Grunt,代码很难阅读,现在出了Gulp, 真是摆脱了痛苦.发现了一篇很好的Gulp英文教程,整理翻译给大家看看. 为什么使用GulpGulp基于Node.js的前端构建工具,通过Gulp的插件可以实现前端 代码的编译(sass.less).压缩.测试:图片的压缩:浏览器自动刷新,还有许多 强大的插件可以在这里查找.比起Grunt不仅配置简单而且更容易阅读和维护,我们 可以做一个对比: Grunt: sass: { dist

VB.NET入门基础

众所周知,Visual Basic.NET是由Visual Basic发展而来,这两者之间的升级使得Visual Basic语言发生了革命性的变革,使得由基于对象编程的Visual Basic过渡到了全然面向对象的Visual Basic.NET.这也使得VisualBasic.NET更加难以掌握,可是原来VB中的一些使用方法依旧延续了下来,本篇博客不讨论它们之间的使用方法,也不讨论两种语言的异同,仅仅介绍VB.NET的基础内容. 废话不多说,先来一张图概述VB.NET的基本内容. 本篇博客将V