第十五章 接口

1、接口: C++中允许多继承没有接口的概念。而java与C#中有,因为C#中 是单继承多接口。

所谓的接口,其实和抽象类、方法相似。都只有一个空方法。其本身不可以为基类,但是允许被其他类继承,而后由其他类或结构实现里面的方法。

2、接口是引用类型

它和继承类似,我们之前可以通过基类的引用的实例化可以访问到派生类当中的方法。在此,我们也可以通过强制转换为接口引用,从而访问实现接口类当中的方法。

interface iifc1

{

void PrintOut(string s);

}

class myclass : iifc1

{

public void PrintOut(string s);

}

{

myclass mc11 = new myclass();

mc11.PrintOut("i lvoe you!");

iifc1 ifc = (iifc1)mc11;//将类对象的引用转换为接口类型的引用。

ifc.PrintOut("i love you!");//调用引用的方法

}

注:实现接口的类可以从它基类继承实现的代码。也就是说,我可以自己不实现,让基类实现也可以。

派生类为继承接口的。

如果两个接口函数里面都有同样的函数需要实现的话,我们可以采用显式接口成员实现。就是 在实现的时候加上接口名 即可。这样不会造成冲突。

interface iifc1

{

void PrintOut(string s);

}

interface iifc2

{

void PrintOut(string s);

}

class myclass : iifc1, iifc2

{

public void iifc1.PrintOut(string s) { }

public void iifc2.PrintOut(string s) { }

}

接口也可以继承接口,不同的类可以实现同一个接口。

第十六章 转换

隐式转换:就是自动转换。

显式转换:就是强制转换。

下面是转换的类型:

我们也可以通过 检测转换结果是否溢出的能力,叫做 溢出检测上下文。

Unchecked(表达式);

对于引用转换:有一点点不一样。

注:从衍生类(派生类)到基类的转换都是隐式转换。

装箱与拆箱:

整个装箱与拆箱的过程如下:

//下面是拆箱与装箱的过程,其实就是通过object为中介,把数据变成可转换的类型。

int i = 10;

object oi = i;//对i装箱并把引用赋值为oi

int ii = (int)oi;//对oi拆箱并把值赋值给ii

用户自定义转换:

通过关键字:implicit 与 explicit 实现。

Public static implicit operator TargetType(SourceType Identifier){ }

两种运算符 : is 与 as

is 主要是用来 检查 从一种类型转换为另一种类型是否会成功。这个有预判效果,事前判断。与unchecked 事后判断不一样。

as 与强制转换类似,假如转换失败,返回null而不抛出异常。

If(bill is Person)

{

P = bill; //这个时候才转换成功。

}

P = bill as Person;

If(p != null)

{

//已经转换成功。

}

C#总结复习5(需要进一步复习)的更多相关文章

  1. C#复习总结6 (需要进一步复习)

    第十七章 泛型 什么是泛型 泛型是为了适应多种不同种类的数据类型而存在的.有了它之后,我们可以不用为不同的数据类型而单独写一个适配.这样很麻烦. 类型不是对象,而是对象的模板.泛型类型也不是类型,而是 ...

  2. 【JS复习笔记】07 复习感想

    好吧,其实<JavaScript语言精粹>后面还简单介绍了代码风格,优美特性,以及包含的毒瘤.糟粕. 但我很快就看完了,发现其实都在前面讲过了,所以就不写了. 至今为止已经算是把JavaS ...

  3. JavaSE复习_11 IO流复习

    △FileReader是使用默认码表读取文件, 如果需要使用指定码表读取, 那么可以使用InputStreamReader(字节流,编码表)    FileWriter是使用默认码表写出文件, 如果需 ...

  4. JavaSE复习_9 集合框架复习

    △列表迭代器也是不支持在迭代的时候添加元素的,只是列表迭代器自己定义了增删的方法而已.迭代器可以看成实在两个元素之间的指针,每当调用next就跳过一个元素并返回刚刚跳过的元素. △HashTable不 ...

  5. 从0开始复习JS---1、函数复习

    1. 写一个函数,实现对数字数组的排序. function get_order(array){ for(var i = 0; i <array.length-1; i++){ for(var j ...

  6. noip初赛复习总纲

    初赛复习总纲 目录 初赛复习总纲 计算机发展史 计算机的分类 计算机的应用 操作系统盘点 计算机的基本结构 中央处理器(**CPU**--**Central Processing Unit**) 存储 ...

  7. HDOJ(HDU) 2078 复习时间

    Problem Description 为了能过个好年,xhd开始复习了,于是每天晚上背着书往教室跑.xhd复习有个习惯,在复习完一门课后,他总是挑一门更简单的课进行复习,而他复习这门课的效率为两门课 ...

  8. 5J - 复习时间

    为了能过个好年,xhd开始复习了,于是每天晚上背着书往教室跑.xhd复习有个习惯,在复习完一门课后,他总是挑一门更简单的课进行复习,而他复习这门课的效率为两门课的难度差的平方,而复习第一门课的效率为1 ...

  9. HDU 2078 复习时间

    http://acm.hdu.edu.cn/showproblem.php?pid=2078 Problem Description 为了能过个好年,xhd开始复习了,于是每天晚上背着书往教室跑.xh ...

随机推荐

  1. MarkdownPad 2 HTML 渲染错误解决办法

    MarkdownPad 2 HTML 渲染错误解决办法 1. 安装SDK工具包 Awesomium 1.6.6 SDK 2. 安装渲染插件Microsoft’s DirectX End-User Ru ...

  2. SPOJ - ADAQUEUE ,双端队列简单运用!

    ADAQUEUE - Ada and Queue 表示这题是学弟带的榜,题还没看完,学弟吐了一句:这不就是双端队列嘛.于是掏出布满尘埃的<曾粽根ACM程序设计>,嗯,确实是裸题,现学现做. ...

  3. RR隔离级别下通过next-key locks 避免幻影读

    ---恢复内容开始--- mysql innodb目前使用范围最广的两种隔离级别为RC和RR,RR修复了RC中所存在的不可重复读 READ COMMITED 不可重复读 在同一事务中两次查看的结果集不 ...

  4. 【bzoj4826】[Hnoi2017]影魔 单调栈+可持久化线段树

    题目描述 影魔,奈文摩尔,据说有着一个诗人的灵魂.事实上,他吞噬的诗人灵魂早已成千上万.千百年来,他收集了各式各样的灵魂,包括诗人.牧师.帝王.乞丐.奴隶.罪人,当然,还有英雄.每一个灵魂,都有着自己 ...

  5. 【Luogu】P2331最大子矩阵(DP)

    题目链接 这题的状态转移方程真是粗鄙. f[i][j][k]表示前i行用了j个矩阵状态为k的时候的最大值. k=0:两列都不选. k=1:取左弃右. k=2:选右弃左. k=3:左右都选,但分属于两个 ...

  6. 原 .NET/C# 反射的的性能数据,以及高性能开发建议(反射获取 Attribute 和反射调用方法)

    大家都说反射耗性能,但是到底有多耗性能,哪些反射方法更耗性能:这些问题却没有统一的描述. 本文将用数据说明反射各个方法和替代方法的性能差异,并提供一些反射代码的编写建议.为了解决反射的性能问题,你可以 ...

  7. BZOJ 3757 苹果树 ——莫队算法

    挺好的一道题目,怎么就没有版权了呢?大数据拍过了,精神AC.... 发现几种颜色这性质比较垃圾,不可加,莫队硬上. %了一发popoqqq大神的博客, 看了一波VFK关于糖果公园的博客, 又找了wjm ...

  8. P1026 统计单词个数 (动态规划)

    题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的单 ...

  9. bzoj 4401 块的计数 思想+模拟+贪心

    块的计数 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 455  Solved: 261[Submit][Status][Discuss] Descr ...

  10. ElasticSearch聚合aggs入门

    Elasticsearch是一款功能强大的开源软件,不仅可以检索排序,还可以对文档进行更复杂的操作--聚合. 1.单值聚合 Sum求和,dsl参考如下: { "size": 0, ...