C#入门经典(第五版)学习笔记(三)

---------------面向对象编程简介---------------

UML表示方法:

  1)方框上中下三分

  2)上框写类名

  3)中框写属性和字段,例如:+Description:string +公共成员-私有成员  Description成员名  string成员类型

  4)下框写方法,例如:+AddSugar(in amount:byte):byte +公共成员-私有成员 in/out/inout数据流方向

  5)静态成员带下划线

  6)接口:画在类名边,棒棒糖型

  7)继承:从子类向父类的箭头

构造函数: 构造函数与类同名,默认构造函数无参数,可定义带参数的非默认构造函数

静态成员: 静态成员可在类的实例间共享,可看做类的全局对象

---------------定义类---------------

class关键字定义类

类的修饰符关键字:

  public/protected/private  公共类/受保护类/私有类

  abstract/sealed  抽象类(不能实例化,只能继承)/密封类(不能继承)

继承: 先继承基类,然后才能指定支持的接口,不得反转,接口可支持多个

interface关键字定义接口

接口的修饰符关键字:

  public  公共接口

---------------定义类成员---------------

可用关键字static,表示静态成员

 定义字段可用关键字readonly,表示只能在执行构造函数过程中赋值,或由初始化赋值语句赋值

 定义方法关键字:

  virtual——方法可重写

  abstract——方法必须在非抽象的派生类中重写(只用于抽象类中)

  override——方法重写了一个基类方法

  extern——方法定义放在其他地方

 定义属性可用get{}set{}代码块,可用virtual/override/abstract关键字

显式隐藏基类方法:

 1 public class MyBaseClass
 2  {
 3      public void DoSomething()
 4      {}
 5  }
 6  public class MyDerivedClass : MyBaseClass
 7  {
 8      new public void DoSomething()
 9      {}
10  }

注意隐藏和重写的区别

接口的实现:

 1)所有接口成员都是公共的

 2)接口成员不能包含代码体

 3)接口不能定义字段成员

 4)接口成员不能用关键字static/virtual/abstract/sealed来定义

 5)类型定义成员是禁止的

在类中实现接口:

 实现接口的类必须包含该接口所有成员的实现代码,且必须匹配指定的签名(包括匹配指定get和set块),并且必须是公共的

 可用关键字virtual或abstract来实现,也可在基类上实现接口

 如果显式实现接口成员,那该成员就只能通过接口来访问,不能通过类来访问

 例如:

1 public class MyClass:IMyInterface
2 {
3      public void IMyInterface.DoSomething()
4      {}
5      public void DoSomethingElse()
6      {}
7 }

由于DoSomething()是显式实现的,而DoSomethingElse()是隐式实现的,之后后者可以直接通过MyClass的对象实例来访问。

部分类定义:

 把类的定义放在多个文件中,需要对每个此类的定义文件中使用partial关键字 例如:

1 public partial class MyClass
2 {
3     …
4 }

在另一个文件中

1 public partial class MyClass
2 {
3     …
4 }
时间: 2024-08-28 17:38:30

C#入门经典(第五版)学习笔记(三)的相关文章

C++ Primer(第五版)学习笔记_1_标准模板库--快速入门

C++ Primer(第五版)学习笔记_1_标准模板库--快速入门 欢迎大家阅读参考,如有错误或疑问请留言纠正,谢谢 标准模板库(STL)提供三种类型的组件:容器.迭代器和算法,他们都支持泛型程序设计标准. 容器主要有两类:顺序容器和关联容器.顺序容器(vector.list.deque和string等)是一系列元素的有序集合.关联容器(set.multiset.map和multimap)包含查找元素的键值. 迭代器的作用是遍历容器. STL算法库包含四类算法:排序算法.不可变序算法.变序性算法

C++ Primer 第五版学习笔记

<C++ Primer>第五版中文版学习笔记 ? C++ Primer 第五版学习笔记

C++ Primer(第五版)学习笔记_9_标准模板库_multimap多重映照容器

C++ Primer(第五版)学习笔记_9_标准模板库_multimap多重映照容器 多重映照容器multimap与map结构基本相同,但由于重复键值存在,所以multimap的元素插入.删除.查找都与map的方法不相同. 1.multimap对象创建.元素插入 插入元素时,需要使用insert()方法和类似pair<string,double>("Jack", 300.5)的元素结构.可以看到,重复的元素是按照插入的先后顺序排序的. #include <iostre

C++ Primer(第五版)学习笔记_5_标准模板库string(2)

C++ Primer(第五版)学习笔记_5_标准模板库string(2) 10.搜索string对象的元素或子串 采用find()方法可查找字符串中的第一个字符元素(char, 用单引号界定)或者子串(用双引号界定):如果查到,则返回下标值(从0开始计数),如果查不到,则返回一个很大的数string:npos(即:4294967295). #include <iostream> #include <stdio.h> #include <string> using nam

C++ Primer(第五版)学习笔记_3_标准模板库vector(2)

C++ Primer(第五版)学习笔记_3_标准模板库vector(2) 欢迎大家阅读参考,如有错误或疑问请留言纠正,谢谢 6.元素的插入 insert()方法可以在vector对象的任意位置前插入一个新的元素,同时,vector自动扩张一个元素空间,插入位置后的所有元素依次向后挪动一个位置. 要注意的是,insert()方法要求插入的位置,是元素的迭代器位置,而不是元素的下标. #include <iostream> #include <vector> using namespa

C++ Primer(第五版)学习笔记_2_标准模板库vector(1)

C++ Primer(第五版)学习笔记_2_标准模板库vector(1) 欢迎大家阅读参考,如有错误或疑问请留言纠正,谢谢 向量容器vector不但能像数组一样进行随机访问,还能在尾部插入元素,完全可以替代数组. 值得注意的是,vector具有内存自动管理的功能,对于元素的插入和删除,可以动态调整所占的内存空间. 容器vector的下标是从0开始的,如果vector容器的大小是n,则元素下标为0~n-1,这和数组的一样的.不一样的是,vector可以随时调整其大小. vector重要的方法有三个

C++ Primer(第五版)学习笔记_4_标准模板库string(1)

C++ Primer(第五版)学习笔记_4_标准模板库string(1) 1.创建string对象 创建一个空字符串,其长度为0 #include <iostream> #include <string> using namespace std; int main(int argc, char* argv[]) { string s; cout << s.length() << endl; return 0; } 运行结果: 0 2.给string对象赋值

C++ Primer(第五版)学习笔记_6_标准模板库_set集合容器

C++ Primer(第五版)学习笔记_6_标准模板库_set集合容器 Set集合容器实现了红黑树(Red-BlackTree)的平衡二叉检索树的数据结构,在插入元素时,它会自动调整二叉树的排序,把该元素放到适当的位置. (1)确保每个子树根节点的键值大于左子树所有节点的键值,而小于右子树所有节点的键值: (2)另外,还得确保根节点左子树的高度与右子树的高度相等.这样,二叉树的高度最小,从而检索速度最快. 平衡二叉检索树的检索使用中序遍历算法,检索效率高.默认情况下,将键值由小到大遍历. 对于s

C++ Primer(第五版)学习笔记_8_标准模板库_map映照容器

C++ Primer(第五版)学习笔记_8_标准模板库_map映照容器 map映照容器的元素数据是由一个键值和一个映照数据组成的,键值与映照数据之间具有一一映照的关系. map映照容器的数据结构也是采用红黑树来实现的. 1.map创建.元素插入和遍历访问 #include <iostream> #include <stdio.h> #include <vector> #include <map> #include <string> using n

C++ Primer(第五版)学习笔记_7_标准模板库_multiset多重集合容器

C++ Primer(第五版)学习笔记_7_标准模板库_multiset多重集合容器 多重集合容器multiset与set一样,也是使用红黑树来组织元素数据的,唯一不用的是,multiset允许重复的元素键值插入.其结构示意图如下: 1.multiset元素插入 #include <iostream> #include <stdio.h> #include <vector> #include <set> #include <string> usi