- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我试图实现一种新方法来连接两个 Array
,返回一个包含通用数据类型的 Array
给其他两个。
为了清楚起见,我希望有一种方法可以做类似的事情(知道语法不正确......):
@infix func + <T,U,X where X super T, X super U>(left : Array<T>, right : Array<U>)
-> Array<X>{
//join both arrays
}
总是认为编译器能够检测两个类的共同祖先类型。如果这实际上是不可能的,那么正确的方法是什么?使“ super ”类型显式化?
最佳答案
Swift 的类型推断比您想象的要聪明。秘诀是查看 nil-coalescing 运算符的签名 ??
:
func ??<T>(optional: T?, defaultValue: @autoclosure () -> T) -> T
func ??<T>(optional: T?, defaultValue: @autoclosure () -> T?) -> T?
很明显,使用此运算符时,它会提升 T
成为传递给它的任何类型的最近共同祖先,一直到 Any
,例如:
let i: Int? = 3
let s: String? = "3"
let a: Any? = i ?? s
这可以编译并工作,但是 a
的类型是Any
(这实际上是一个协议(protocol))。在某些情况下,您需要向编译器提供类型证据,而在某些情况下则不需要。如果这些类型共享一个不是协议(protocol)的共同祖先,那么似乎不需要证据。你可能认为 ??
正在得到编译器的特殊对待,但事实并非如此。您可以非常轻松地自己滚动。
来到你的尝试,你因此想多了。 (就像我遇到类似问题时一样。)您只需要一个类型。
如果我们要实现您的 +
作为一个函数,它看起来像这样:
func joinArrays<T>(array1: [T], array2: [T]) -> [T] {
return array1 + array2
}
class Base {}
class Derived1 : Base {}
class Derived2 : Base {}
let a1 = [Derived1(), Derived1()]
let a2 = [Derived2(), Derived2()]
let a = joinArrays(a1, a2)
a
的类型是Array<Base>
,因为这是泛型类型参数的最近共同祖先。
我已经使用这种“类型提升”来创建各种复杂的合并/单子(monad)运算符,就像 Haskell 一样。唯一的小问题是 Swift 不支持泛型类型参数的协变。
关于generics - 在 Swift 泛型中强制父类(super class),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24328747/
问题比较Java,但是我想在Android中实现: 假设有 3 个或更多类相互扩展: class A { ... int color; ... } class B extend
我知道标题听起来有点奇怪,但这正是我愿意做的。简单解释:A类是B类的子类,B类也是C类的子类>. 现在,所有这些类都包含方法m()。在我的 A 类中,这是我唯一可以访问的类,因为其他类仅在运行时可用,
我有一个 UIViewController 类 A 和 B。 A 使用以下方式加载 B:[A.view addSubView B.view]。 B 有一个带有“后退”按钮的导航栏。我想在单击时返回到
我有以下(第三方)类结构。我们将调用第三方项目 ProjectSeriously,并注意我使用 System.out.println 代替其他复杂的功能(100 行代码) . class A {
在下面的代码中,我从 Game 扩展了 MyGame。我有两个问题: 我们是否需要为所有render()、dispose()、pause()调用super方法 和 resize(w,h)?很多人都没有
例如,假设我想在调用 super.viewDidLoad() 时跳过一级。所以我希望能够做这样的事情: override func viewDidLoad() { super.super.vi
public class Faculty extends Employee { public static void main(String[] args) { new Fac
假设我有: class Superclass { //fields... methodA() {...} methodB() {...} ... } class Subclass exte
这个问题在这里已经有了答案: Why is super.super.method(); not allowed in Java? (22 个答案) 关闭 9 年前。 我怀疑我想做的事情是否可行。我有
我有一个实现 Initializable 的类。 public abstract class ExampleClass implements Initializable { public vo
我想知道,我有这个大数组,是否可以只在内存中使用一次而不是每个线程一次?以 stackoverflow 上的标签为例。他们几乎从不改变,为什么不为他们留下一个内存点呢?甚至可能将该数组永久保存在内存中
假设这三个类具有这个简单的层次结构: class A { func foo() { print("A") } } class B: A { override fu
有没有办法在 TypeScript 中调用 super.super.methodName。我想避免调用super.methodName,但我想调用二祖的methodName方法。 谢谢。 最佳答案 T
这个问题已经有答案了: When do I use super()? (11 个回答) 已关闭 7 年前。 package Geometry; public abstract class Geomet
我必须执行and()在我的实现 Predicate 的业务对象上. 出现问题的代码是 and() 行调用: Predicate predicate = new M
我有一个实现接口(interface)的抽象父类(super class): public abstract class FooMatrix implements Matrix { publi
我有四个 UIView:viewA 是 Root View ,它有 viewB 作为它的 subview 。 viewB 将 viewC 作为其 subview ,而 viewC 将 viewD 作为
有什么区别: class Child(SomeBaseClass): def __init__(self): super(Child, self).__init__() 和:
我有一个通用接口(interface) interface ListList extends List> .由于某些原因,我无法转换 ListList至 List> .有什么方法可以做到吗?为什么它不
我想调用带有两个参数的父类(super class)的构造函数,所以我调用了 super(arguments),但是编译器说: “类 Person 中的构造函数 Person 不能应用于给定类型; 要
我是一名优秀的程序员,十分优秀!