- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一些第三方类(class)。其精简版(为了简洁起见)功能如下:
ClassA
和 ClassB
供外部使用。这些类中的每一个类都与其他类完全无关(这意味着它们没有共同的祖先)。handle()
函数,它接受Object
类型的对象作为输入。handle()
函数检查对象的类型是否为 ClassA
或 ClassB
。该类的伪代码及其用法如下:
// Third party code..
class ClassA implements InterfaceA { ... }
class ClassB { ... }
class WeirdCode {
void registerUserMethod(func ...) { }
void handle(Object input) { ... }
}
// My caller code..
function myHandler(T??? obj) {
// Do something with obj
}
WeirdCode weirdCode = new WeirdCode(...);
weirdCode.registerUserMethod(myHandler);
weirdCode.handle(new ClassA(...));
通常,该类应一次专门用于一种类型。因此,我可以使用 ClassA
或 ClassB
,但不能同时使用两者。但是,如果我想同时处理 ClassA
和 ClassB
对象,我必须这样做:
// My caller code..
function myHandlerA(ClassA obj) { ... }
function myHandlerB(ClassB obj) { ... }
WeirdCode weirdCodeA = new WeirdCode(...);
WeirdCode weirdCodeB = new WeirdCode(...);
weirdCodeA.register(myHandlerA);
weirdCodeB.register(myHandlerB);
weirdCodeA.handle(new ClassA(...));
weirdCodeB.handle(new ClassB(...));
我希望能够执行以下操作:
// My caller code..
function myHandlerAB(Object obj) { ... }
WeirdCode weirdCode = new WeirdCode(...);
weirdCode.handle(new ClassA(...));
weirdCode.handle(new ClassB(...));
但是,如果我这样做,WeirdCode
会抛出异常,因为其中包含以下代码:
void handle(Object obj) {
...
if (ClassA.class.isAssignableFrom(obj.getType())) {
...
myHandler(obj);
}
else if (ClassB.class.isAssignableFrom(obj.getType())) {
...
myHandler(obj);
}
else {
throw new Exception();
}
...
}
在整个图中我唯一可以控制的是myHandler()
函数的原型(prototype)。是否可以定义一个类型,使得 ClassA
和 ClassB
都可以从中分配,以及 ClassA
和 ClassB
可以转换到它吗?我认为这是不可能的。但我很乐意被证明是错误的,因为这会帮助我解决我的问题。
最佳答案
The only thing I can control in this entire picture is the prototype of the myHandler() function. Is it possible to define a type such that both ClassA and ClassB are assignable from it, as well as both ClassA and ClassB to be cast-able to it?
所以你想做的是:
MyType myType1 = new ClassA(...);
MyType myType2 = new ClassB(...);
还有...
ClassA clsA = (ClassA) myType1;
ClassB clsB = (ClassB) myType2;
准确吗?
你的致命弱点是你无法控制 ClassA 和 ClassB 的类型。据我了解,这些对象是由第三方代码定义的,您无法修改。听起来您想要做的是提供一种有限多重继承的形式,这可以通过接口(interface)继承来提供。但是,由于您无法控制这些类,因此该解决方案不可行。
尽管 instanceof
运算符经常被 mock 为良好的面向对象软件设计的祸根,但在这种必须与其他人的代码进行互操作的情况下,它是必不可少的。
FWIW,Java 并不以通常理解的方式理解“原型(prototype)”(例如 JavaScript 中的原型(prototype)继承)。您不应该试图强制 Java 理解原型(prototype)继承。
关于Java - IsAssignableFrom 悖论?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34124712/
我想更好地理解 Java 中基本类型和引用类型之间的 isAssignableFrom 行为。 例如: System.out.println(boolean.class.isAssignableFro
我有两个 java 类,如下所示, public class Class1{ private Object actionObject; public Object getActi
不确定我是否可以这样做,但我正在尝试查看一个类型是否继承自具有泛型约束的另一个类型。 这是我要查找的类: public class WorkoutCommentStreamMap : ClassMap
我有一些第三方类(class)。其精简版(为了简洁起见)功能如下: 提供两个类 ClassA 和 ClassB 供外部使用。这些类中的每一个类都与其他类完全无关(这意味着它们没有共同的祖先)。 有一个
我想更好地理解 Java 中基本类型和引用类型之间的 isAssignableFrom 行为。 例如: System.out.println(boolean.class.isAssignableFro
我如何检测类型 x 是否可从类型 y 分配,不仅通过继承层次结构而且通过协变和逆变? 最佳答案 IsAssignableFrom 会检查协变和逆变,您不需要任何其他东西: // Covariance
我有下一个代码: private T CreateInstance(object obj) // where T : ISomeInterface, class { ... if (!
在我写的使用反射的代码中 if (f.FieldType.IsAssignableFrom("".GetType())) 我有一个隐式转换为字符串的类。但是上面的 if 语句没有捕捉到它。如何通过隐式
在 Kotlin (1.0.6) 中,通过反射我需要迭代一个类的成员(我们称之为 Foo),并根据返回类型做一些事情。我可以编写以下内容,它有效: Foo::class.members{ m ->
我真的对这种行为感到困惑。在 JBoss 7 中,我使用 @Entity 注释检索所有类,然后我需要找到所有实现接口(interface)“BusinessObject”的类。 这是实现它的方法:
我正在查看 java.lang.Class#isAssignableFrom来自 Java Reflection in Action . 为什么 Object.class.isAssignableFr
我正在使用 COM-API,Autodesk Inventor。 此测试通过: [Test] public void CastTest() { Inventor.Document docume
我正在尝试创建一个通用包装器来包装所有类型的值并提供一些额外的功能。 包装器看起来像: class PropertyWrapper { private T _value; publi
给定一个 Class 对象,我如何检查它的“祖先”之一是否是某个类?有多次调用 getSuperClass 的替代方法吗? 最佳答案 给定一个类 c1,您想知道它的祖先之一是否是 c2? 不会 c2.
所以我想检查一个类是否可以分配给包含许多子类的父类(super class),像这样 public class A { public A(){ } } public class B exten
我发现原始类型问题 System.out.println("Integer.class.isAssignableFrom(int.class) = " + Integer.class.isAssign
int i=1; long longOne=i; //assignment works fine //...but bool canAssign=(typeof(long).IsAssignableF
实现oauth2系统,我在使用以下代码时遇到一些问题: import org.springframework.security.oauth2.provider.endpoint.FrameworkEn
我有一些 Java 代码需要使用当前支持泛型的编译器以及(尚)不了解泛型的旧版或外来编译器进行编译。除了极少数使用 Class.isAssignableFrom() 的情况外,我设法使几乎所有代码都可
我使用 isAssignableFrom() 类方法来确定其他应用程序中的类是否实现接口(interface)。因此,我在两个“应用程序”中具有相同的接口(interface),但不在同一个包中。当两
我是一名优秀的程序员,十分优秀!