自己从0开始学习Unity的笔记 VII (C#中类继承练习)
好久都没有写了。今天做了类继承的练习,做了一个小队,进行简单的判定。
namespace 兵团建立练习
{
class ServantBasics
{
public string name; //protected 代表着子类可以继承,外部不能调用
protected int attack; public ServantBasics(string name,int attack) //做了一个构造函数,用于赋值
{
this.name = name;
this.attack = attack;
}
} class SaberServant : ServantBasics //用于继承父类函数 这个就是语法
{
public SaberServant(string name, int attack) : base(name, attack) //这个其实是上面输入父类后,然后有个红线自动点击会自动填入,不过我也认真记了一下,和this用法挺像的
{
} public void skill()
{
Console.WriteLine("“EX咖喱棒!!!”");
Console.WriteLine("给对面造成了{0}点伤害",attack); }
} class ArcherServant: ServantBasics //用于继承父类函数
{
public ArcherServant(string name,int attack) : base(name,attack)
{
} public void skill()
{
Console.WriteLine("“无限剑制”");
Console.WriteLine("给对面造成了{0}点伤害", attack);
}
}
class RiderServant : ServantBasics //用于继承父类函数
{
public RiderServant(string name, int attack) : base(name, attack)
{
} public void skill()
{
Console.WriteLine("“无限剑制”");
Console.WriteLine("给对面造成了{0}点伤害", attack);
}
}
class CasterServant : ServantBasics //用于继承父类函数
{
public CasterServant(string name, int attack) : base(name, attack)
{
} public void skill()
{
Console.WriteLine("“万符必应破戒”");
Console.WriteLine("给对面造成了{0}点伤害", attack);
}
} class Program
{
static void Main(string[] args)
{
var r = new Random(); //建立一个随机的骰子
var servantParty = new ServantBasics[]; //建立了一个10个人小队的数组
for (int i = ; i < servantParty.Length; i++)
{
var roll = r.Next(, );
if (roll > )
{
servantParty[i] = new SaberServant("剑士",);
}
else if (roll > )
{
servantParty[i] = new ArcherServant("弓箭手", );
}
else
{
servantParty[i] = new CasterServant("魔法师", );
}
} for (int i = ; i < servantParty.Length; i++)
{
if (servantParty[i] is SaberServant) //我是这样理解的,用父类创建的这个子类,是不是SaberSevrvant
{
SaberServant saber = servantParty[i] as SaberServant; //如果不是返回空,如果是就给saber赋值
Console.WriteLine("这是第{0}个,职业是{1}",i+,saber.name);
saber.skill();
}
else if (servantParty[i] is ArcherServant)
{
Console.WriteLine("这是第{0}个,职业是{1}", i + , (servantParty[i] as ArcherServant).name);
(servantParty[i] as ArcherServant).skill(); //尝试进行简写
}
else
{
Console.WriteLine("这是第{0}个,职业是{1}", i + , (servantParty[i] as CasterServant).name);
(servantParty[i] as CasterServant).skill();
//我自己测试发现不能直接用servantParty[i].skill,没有选项,因为这个数组是基于父类建立的
//这种方法被称为里氏转换,挺神奇的,因为我以为数组都存好了数据new后的数据,居然不能 .skill
}
} Console.ReadKey(); }
}
}
用了一个数组来记录东西,我觉得这样似乎可以做生成地图随机怪兽的玩意,所以记录下来,方便以后忘记时候来看看,可能会有帮助
自己从0开始学习Unity的笔记 VII (C#中类继承练习)的更多相关文章
- 自己从0开始学习Unity的笔记 I (C#字符串转换为数字)
		我基本上从0开始学习编程,运算符基本上跳过,因为知道了 “=”这个符号相当于赋值,然后“==”才是等于,其他和普通运算符号差不都,也就跳过了. 最基础的赋值那种,我看了下代码,似乎没什么难度,估计新手 ... 
- 自己从0开始学习Unity的笔记 VI (C#的for循环练习)
		最近学到了for循环,我觉得其实看情况吧,和while挺像的,不过适合于累加或者累减这类的,for循环要更好用一点 for循环首先格式是 ; i < length; i++) { } 意思很简单 ... 
- 自己从0开始学习Unity的笔记 V (C#的数组练习)
		今天练习了数组输入,先从最简单的开始,因为我输入完这些之后,觉得应该有更简单的方法,先来介绍一下我做的练习代码 //做一个最多能容纳10个数字的,用户可以输入任意1-10个数字,判断长度,输出数字 ] ... 
- 自己从0开始学习Unity的笔记 IV (C#循环练习-数字猜谜游戏)
		想起来现在基础的已经学了不少了,那么这次试一下用while写一个数字猜谜的. Random roll = new Random(); //建立一个骰子 , ); //让骰子在1-100内随机一个数 ; ... 
- 自己从0开始学习Unity的笔记 IV (C#循环练习输出素数)
		来测试一下循环....刚刚学了while循环,测试一下输出1-100的素数 我想了一下,素数就是只能被1和本身整除,那就是只能被整除2次,我是顺着这个思路写的代码,如果被整除超过2次,那么肯定不是素数 ... 
- 自己从0开始学习Unity的笔记 III (C#随机数产生基础练习)
		自己开始尝试弄一下随机数,照着方法,自己做了个英雄打怪兽的测试 int heroAttack; ; ; Random attack = new Random(); //初始化一个随机数的类 heroA ... 
- 自己从0开始学习Unity的笔记 II (C#条件语句基础练习)
		首先,自己用了下三目表达式,来做了一个闰年的判断,也就是能被400整除,或者是能够被4整除,但是不能被100整除的年份. int year; //输入的年 bool fourHunderd; //能被 ... 
- 自己从0开始学习Unity的笔记 VIII (C#中类继承练习 II)
		自己写了一个关于兵种的,因为一直在测试,到底面向对象是个什么玩意...然后就做了这个 namespace 兵种 { class Role //作为父类,构建一个普通角色属性用于继承 { protect ... 
- 从0开始学习Unity的学习笔记(I 界面学习和简单模型拼装)
		先给一个大致今天学习的图,然后后面是细节 1.下载Unity :官网下载需要版本 2.Unity安装:一定不要有中文路径:一台电脑可以安装不同版本的Unity,但是要安装在不同的文件夹下: 3. 新建 ... 
随机推荐
- 全面解析python类的绑定方法与非绑定方法
			类中的方法有两类: 绑定方法 非绑定方法 一.绑定方法 1.对象的绑定方法 首先我们明确一个知识点,凡是类中的方法或函数,默认情况下都是绑定给对象使用的.下面,我们通过实例,来慢慢解析绑定方法的应用. ... 
- 4_bootstrap之栅格系统
			4.栅格系统 4.1.简述栅格系统 为了方便在布局容器中进行网页的布局操作. BootStrap提供了一套专门用于响应式开发布局的栅格系统. 栅格系统将一行分为12列,通过设定元素占用的列数来 布局元 ... 
- 好记性不如烂笔头-linux学习笔记1
			好记性不如烂笔头-linux学习笔记1 linux的文件系统有ext2,ext3,ext4,目前主流是ext4 linux主要用于服务器级别的操作系统,安装时需要至少2个分区 一个是交换分区,swap ... 
- leetcode110
			/** * Definition for a binary tree node. * public class TreeNode { * public int val; * public TreeNo ... 
- LevelDB Cache机制
			[LevelDB Cache机制] 对于levelDb来说,读取操作如果没有在内存的memtable中找到记录,要多次进行磁盘访问操作.假设最优情况,即第一次就在level 0中最新的文件中找到了这个 ... 
- linux之cut
			[linux之cut] -b:字节 -c:字符 -d:自定义域 -f:域范围 参考:http://wenku.baidu.com/view/9399bc8383d049649b66588b.html 
- java.io.FileNotFoundException(系统找不到指定的路径。)
			报错:java.io.FileNotFoundException(系统找不到指定的路径.) 解决方法: 1.检查文件路径是否正确 2.另外,使用OutputStream时,如果文件不存在,会自动创建文 ... 
- JS 将json数组转为嵌套层级数组
			ele UI 的树级菜单的数据要求是这种嵌套的,但是Ztree的老用发的是 var zNodes =[ { id:, pId:, name:"zTree Home", pid:0} ... 
- RNA-Seq differential expression analysis: An extended review and a software tool   RNA-Seq差异表达分析: 扩展评论和软件工具
			RNA-Seq differential expression analysis: An extended review and a software tool RNA-Seq差异表达分析: 扩展 ... 
- mysql索引原理及用法
			MySQL索引原理及慢查询优化 Mysql explain用法和性能分析 MySQL 索引优化全攻略 1.索引作用 在索引列上,除了上面提到的有序查找之外,数据库利用各种各样的快速定位技术,能够大大提 ... 
