我正在将一些Java代码移植到Dart,它大量使用这些类型的地图:
Map<Class<? extends SomeClass>, SomeOtherClass> map = new HashMap<>();
目前这在飞镖中似乎是不可能的。我知道有一个提议引入第一级类型:http://news.dartlang.org/2012/06/proposal-for-first-class-types-in-dart.html将引入
class Type {
@native String toString();
String descriptor(){...} // return the simple name of the type
}
因此,在实施此提案之前,我创建了以下类:
class Type {
final String classname;
const Type(this.classname);
String descriptor() => classname;
}
我需要它的类有一个简单的get-method
abstract Type get type();
这样我可以使用我的Type
,就像我使用真正的Type
一样,稍后切换我只需要删除我的解决方法。
我的问题:是否有一些方法可以进行这种映射(我没有看到),或者我是否采用合理的解决方法直到真正的Type
类被引入?
Dart 1.0更新
可以这样做:
var map = new Map<Type, SomeOtherClass>();
// either
map[SomeOtherClass] = new SomeOtherClass();
// or
var instance = new SomeOtherClass();
map[instance.runtimeType] = instance;
答案 0 :(得分:5)
更新:Dart
目前无法使用此构造Map<Class<? extends SomeClass>, SomeOtherClass>
你必须等待 .type / .class 才能找到一个优雅的解决方案(很多我们的Dartisans希望这会早点而不是晚点到达)。但是对于更简单的情况
Map<? extends SomeClass, SomeOtherClass>
你可以做到
Map<SomeClass, SomeOtherClass> aMap;
与Dart一样,任何扩展 SomeClass 的类也将是有效的 SomeClass 。例如,如果在选中模式下运行以下代码:
main() {
Map<Test, String> aMap = new HashMap<Test, String>();
var test = new Test("hello");
var someTest = new SomeTest("world");
var notATest = new NotATest();
aMap[test] = test.msg;
aMap[someTest] = someTest.msg;
aMap[notATest] = "this fails";
}
class Test implements Hashable {
Test(this.msg);
int hashCode() => msg.hashCode();
final String msg;
}
class SomeTest extends Test {
SomeTest(String message): super(message);
}
class NotATest implements Hashable {
int hashCode() => 1;
}
然后你会得到错误:
type 'NotATest' is not a subtype of type 'Test' of 'key'.