- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有几个与java中的oop相关的问题。
我理解is-a关系意味着继承。
我知道可以做关系意味着我需要实现接口(interface)。
这里出现问题:
现在,如果我有更多变量,例如:
在 Square 类中 -> int side;在 Rectangle 类中 -> int width , int height...等等。
如果我按照建议的良好做法进行操作,即创建一个接口(interface)实例
Shape s = new Square();
那么我无法访问实例变量side。
所以,我不得不依赖这样的东西:
Square s = new Square();
s.side = 3;
s.draw();
在继承的情况下也会出现同样的问题。例如:
public class Animal{
}
public class Reptile extends Animal{
}
public class Dog extends Animal{
}
现在,如果我尝试这样的事情:
狗有自己的变量,如 dentry 、腿和眼睛。
Animal a = new Dog();
a.teeth = 30; // will not work
或者
按照这样的做法正确吗:
Dog d = new Dog();
d.teeth = 30;
那么,我缺少一些设计细节吗?请解释一下。
我尽力做出正确的设计。只是偶然发现了这些东西。
最佳答案
我没有发现与您的设计相关的继承和多态性有任何问题。 (除非我想说正方形、圆形、矩形都是形状,所以也许可以使用继承来代替)。不过,您可能缺少一些有关 Java 语法的内容。
考虑任何声明:
A test = new B()
第一个关键字,A
,告诉计算机变量的类型是什么。在这种情况下,您向计算机保证您的变量引用的任何内容都将是 A
。第二个关键字test
, 只是变量的名称。第三部分,= new B()
告诉计算机您正在分配 test
引用 B
类型的新对象。只要B
是 A
,你很好。
现在让我们考虑第一个示例,其中 Square
和Shape
。如果你说
Shape s = new Square()
您正在告诉计算机 s
引用 Shape
- 即“无论 s
所指的始终是 Shape
。当您设置它 = new Square()
时,您是在说您希望它引用 Square
。这很好,因为 Square
< em>是一个 Shape
。但是,你不能说 s.side = 3
因为 s
你只能保证计算机 s
引用 Shape
而不是所有 Shape
都刚刚1 边长。
出于矛盾考虑,假设您应该能够访问 s.side。那么如何协调这两个代码块呢?
Square s = new Square();
s.side = 3;
System.out.println( s.side );
Shape s = new Square();
s.side = 3;
s = new Circle();
System.out.println( s.side );
显然是Circle
没有一方会“规避”我们的逻辑。
另一方面,如果你说
Square s = new Square();
你保证电脑无论如何s
指的是会有一个side
属性(property),因此您可以访问 s.side
.
补充:具体回答您的问题“那么,我缺少一些设计细节?”
我认为您没有遗漏设计细节。我认为您只是不太明白代码的含义。例如,有些情况你想说
Animal a = new Dog();
有些情况你想说
Dog a = new Dog();
在确定您要使用的类型标识符(动物或狗)时,您会问自己一个问题:“我是在动物还是狗上进行操作?”如果你对动物进行手术,你会说
Animal a = new Animal();
然后,您可以进行更复杂的操作。例如,如果您有一个动物列表,并且所有动物都有一个方法 live()
,然后您可以浏览列表并将所有动物设为 live()
不必担心它是狗、猫还是 Camel 。代码:
ArrayList< Animal > listOfAnimals = new ArrayList< Animal >();
//populate the list
for ( Animal a : listOfAnimals ) {
a.live();
}
如果您只对狗进行手术(例如,您需要它们全部咬人),那么您必须使用Dog
标识符。代码:
ArrayList< Dog > listOfDogs = new ArrayList< Dog >();
//populate the list
for ( Dog d : listOfDogs ) {
d.bite();
}
如果我们声明 ArrayList< Animal > listOfDogs = new ArrayList< Animal >();
会出现什么问题并制作了每个元素bite()
?
关于Java oop 继承和接口(interface),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30371769/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
在面向对象的编程中,“基类”是派生其他类的类(http://en.wikipedia.org/wiki/Base_class)。 但是,基类的反面是什么?换句话说,什么是没有任何子类的类? 编辑:我正
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 8年前关闭。 Improve this questi
据我了解,OOP 是大型项目最常用的范式。我也知道大系统的一些较小的子集使用其他范式(例如 SQL,它是声明性的),并且我也意识到在较低级别的计算 OOP 并不真正可行。但在我看来,通常更高级别的解决
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
最近听说OOP(Java)有9条规则。我只知道四种:抽象、多态、继承和封装。 OOP 还有更多规则吗? 最佳答案 看来您正在寻找的是 Principles of Object-Oriented Des
我曾经在一次采访中被问到“OOP 的 3 个主要概念是什么?”。我回答说,我认为有4个,如下: 继承 封装 抽象 多态性 我说得对吗? 最佳答案 语言要成为面向对象有3个要求: 仅支持封装(对象)的语
我有一个关于特定 OOP 问题的组织的简单问题。 假设我有一个地形类,里面充满了瓷砖。 Tile 类有多个派生类,即 Door。 Door 类有一个名为 open() 的方法,用于打开门,还有一个名为
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是 Go 的新手,然后我通过示例搜索了很多如何拥有带有静态函数/变量的静态类,例如 C#。但是,我找不到任何可以很好地回答它的东西。也许这个问题看起来很愚蠢,但我不喜欢不确定或不完全理解某事。 假设
我曾尝试搜索此问题的答案,但很难用语言表达,而且许多问题要么是关于如何创建类,要么是关于如何做非常具体的事情。我需要更多的实用概述 - 我是自学成才的,我了解对象是什么(以及如何创建它们),但我从未见
在开始编码之前,我通常会尝试在没有太多分析(没有图表)的情况下进行 TDD。通常我发现自己将一个类拆分为其他类以分离关注点。我想知道更深入的分析是否会阻止这种情况。我认为大部分面向对象分析无法预测其中
在阅读单例时,我发现这个解释是使用单例的原因: since these object methods are not changing the internal class state, we can
如这里所述 https://standardofnorms.wordpress.com/2012/09/02/4-pillars-of-object-oriented-programming/ 并作为
我是这个网站的新手,所以如果我在发布问题时做错了什么,请告诉我,以便我下次修复。 我很好奇从单个基类继承多个类是否是糟糕的 OOP 实践。这可能不太合理,所以我要详细说明一下。 例如,假设您正在设计一
我对“工厂相关”设计模式及其 OOP 实现的理解一直很简单。 一个 《工厂法》是类内部的一个方法,它有一个接口(interface)(或抽象类)作为返回类型,并根据一些内部逻辑构造实现该接口(inte
C# 中的“密封”关键字,Java 中的 Final。 因为我几乎从不创建任何图表并且我只使用已经完成的类(来自框架)我多年后仍然不知道为什么有人会“锁定”一个类所以它永远不会被扩展/继承。 它是有益
我正在研究面向对象的概念,抽象概念基本上被描述为对用户隐藏实现。因此,如果类中有一个成员函数并且我们为某些任务调用该函数,抽象表示用户不应该关心事情是如何完成的,而应该只知道正在完成什么。但即使在非面
我是一名优秀的程序员,十分优秀!