继承主要实现重用代码,来节省开发时间。
一个类B继承一个类A,被继承的类A称为 父类、基类、超类,继承的类B称为 子类、派生类。
特点:
class Teacher
{
public string name;
public int number;
public void SpeakName()
{
Console.WriteLine(name);
}
}
class TeachingTeacher : Teacher
{
public string subject;//科目
public void SpeakSubject()
{
Console.WriteLine($"我是{subject}老师");
}
}
class ChineseTeacher : TeachingTeacher
{
public void Skill()
{
Console.WriteLine("余幼时即嗜学");
}
}
TeachingTeacher tt = new TeachingTeacher();
tt.name = "abc";
tt.number = 1;
tt.SpeakName();
tt.subject = "C#";
tt.SpeakSubject();
ChineseTeacher ct = new ChineseTeacher();
ct.name = "def";
ct.number = 2;
ct.SpeakName();
ct.subject = "Chinese";
ct.SpeakSubject();
ct.Skill();
里氏替换原则(Liskov Substitution principle):子类可以扩展父类的功能,但不能改变父类原有的功能,是面向对象七大原则中最重要的原则。
概念:任何父类出现的地方,子类都可以替代
重点:语法表现一父类容器装子类对象,因为子类对象包含了父类的所有内容
作用:方便进行对象存储和管理
class GameObject
{
}
class Player : GameObject
{
public void PlayerAttack()
{
Console.WriteLine("玩家攻击");
}
}
class Monster : GameObject
{
public void MonsterAttack()
{
Console.WriteLine("怪物攻击");
}
}
class Boss : GameObject
{
public void BossAttack()
{
Console.WriteLine("Boss攻击");
}
}
//Main
//里氏替换原则 用父类容器装载子类对象
GameObject p = new Player();
GameObject m = new Monster();
GameObject b = new Boss();
is:判断一个对象是否为指定对象,返回:bool,是为真,不是为假
as:将一个对象转换为指定类对象,返回:成功返回指定类对象,失败返回null
基本语法:
if(p is Player)
{
Player p1 = p as Player;
p1.PlayerAttack();
}
子类声明子类对象时,先执行父类的构造函数,再执行子类的构造函数。
class GameObject
{
public GameObject()
{
Console.WriteLine("GameObject的构造函数");
}
}
class Player : GameObject
{
public Player()
{
Console.WriteLine("Player的构造函数");
}
}
class MainPlayer : Player
{
public MainPlayer()
{
Console.WriteLine("MainPlayer的构造函数");
}
}
//Main
MainPlayer mp = new MainPlayer();
/*
输出:
GameObject的构造函数
Player的构造函数
MainPlayer的构造函数
*/
Father构造
Son一个参数构造
Son两个个参数构造
通过 base(参数) 可以调用指定父类构造。
class Father
{
/*public Father()
{
}*/
public Father(int i)//有参构造函数会自动顶掉无参构造函数
{
Console.WriteLine("Father构造");
}
}
//子类实例化时默认先调用父类的无参构造,如果父类无参构造被顶掉,就会报错
class Son : Father
{
//通过base改变默认调用父类的无参构造,指定为有参构造
public Son(int i) : base(i)
{
Console.WriteLine("Son一个参数构造");
}
public Son(int i, string str) : this(i)//this(i)表示调用一个参数的构造函数public Son(int i) : base(i){}
{
Console.WriteLine("Son两个个参数构造");
}
}
//Main
Son s = new Son(1, "123");
/*
输出:
Father构造
Son一个参数构造
Son两个个参数构造
*/
object 是所有类型的父类,它是一个类(引用类型)。
作用:
class Father
{
}
class Son : Father
{
public void Speak()
{
}
}
//Main
Father f = new Son();//用父类容器装载子类
if(f is Son)
{
(f as Son).Speak();
}
//用object装载万物,然后转换成所需类型来使用
//1、引用类型
object o = new Son();
//用is和as来判断和转换即可
if(o is Son)
{
(o as Son).Speak();
}
//2、值类型
object o2 = 1f;
//用强转
float fl = (float)o2;
//特殊string类型
object str = "123";
string str2 = str as string;
//数组
object arr = new int[10];
int[] ar = arr as int[];
object v = 3;//装箱
int a = (int)v;//拆箱
sealed class Father
{
}
class Son : Father//报错,无法继承
{
}
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我在Rails工作并有以下类(class):classPlayer当我运行时bundleexecrailsconsole然后尝试:a=Player.new("me",5.0,"UCLA")我回来了:=>#我不知道为什么Player对象不会在这里初始化。关于可能导致此问题的操作/解释的任何建议?谢谢,马里奥格 最佳答案 havenoideawhythePlayerobjectwouldn'tbeinitializedhere它没有初始化很简单,因为你还没有初始化它!您已经覆盖了ActiveRecord::Base初始化方法,但您没有调
我有一个服务模型/表及其注册表。在表单中,我几乎拥有服务的所有字段,但我想在验证服务对象之前自动设置其中一些值。示例:--服务Controller#创建Action:defcreate@service=Service.new@service_form=ServiceFormObject.new(@service)@service_form.validate(params[:service_form_object])and@service_form.saverespond_with(@service_form,location:admin_services_path)end在验证@ser
如何在ruby中调用C#dll? 最佳答案 我能想到几种可能性:为您的DLL编写(或找人编写)一个COM包装器,如果它还没有,则使用Ruby的WIN32OLE库来调用它;看看RubyCLR,其中一位作者是JohnLam,他继续在Microsoft从事IronRuby方面的工作。(估计不会再维护了,可能不支持.Net2.0以上的版本);正如其他地方已经提到的,看看使用IronRuby,如果这是您的技术选择。有一个主题是here.请注意,最后一篇文章实际上来自JohnLam(看起来像是2009年3月),他似乎很自在地断言RubyCL
我想让一个yaml对象引用另一个,如下所示:intro:"Hello,dearuser."registration:$introThanksforregistering!new_message:$introYouhaveanewmessage!上面的语法只是它如何工作的一个例子(这也是它在thiscpanmodule中的工作方式。)我正在使用标准的rubyyaml解析器。这可能吗? 最佳答案 一些yaml对象确实引用了其他对象:irb>require'yaml'#=>trueirb>str="hello"#=>"hello"ir
假设我有一个FireNinja我的数据库中的对象,使用单表继承存储。后来才知道他真的是WaterNinja.将他更改为不同的子类的最干净的方法是什么?更好的是,我很想创建一个新的WaterNinja对象并替换旧的FireNinja在数据库中,保留ID。编辑我知道如何创建新的WaterNinja来self现有FireNinja的对象,我也知道我可以删除旧的并保存新的。我想做的是改变现有项目的类别。我是通过创建一个新对象并执行一些ActiveRecord魔法来替换行,还是通过对对象本身做一些疯狂的事情,或者甚至通过删除它并使用相同的ID重新插入来做到这一点,这是问题的一部分。