我正在尝试Swift书中的一些示例,即它们具有的矩阵示例,其中引入了下标选项。这是我的代码:
struct Matrix<T> {
let rows: Int, columns: Int
var grid: T[]
var description: String {
return "\(grid)"
}
init(rows: Int, columns: Int, initialValue: T) {
self.rows = rows
self.columns = columns
grid = Array(count: rows * columns, repeatedValue: initialValue)
}
func indexIsValidForRow(row: Int, column: Int) -> Bool {
return row >= 0 && row < rows && column >= 0 && column < columns
}
subscript(row: Int, column: Int) -> T {
get {
assert(indexIsValidForRow(row, column: column), "Index out of range")
return grid[(row * columns) + column]
}
set {
assert(indexIsValidForRow(row, column: column), "Index out of range")
grid[(row * columns) + column] = newValue
}
}
}
这大部分是从书中复制的。这里的主要区别是:
struct Matrix<T>
据我所知,这告诉编译器我的Matrix类可以保存类型T的值,该值由使用此类的代码指定。现在,我想确保可以比较类型T,所以我可以这样写:
struct Matrix<T: Equatable>
如果我要比较2个矩阵(这意味着比较它们的值),这可能很有用。我还希望提供对两个矩阵求和的能力,因此我还应该在此行中添加一个协议,要求可以添加矩阵用户给出的类型“
T”:
struct Matrix<T: Equatable, "Summable">
同样,我也想说:
struct Matrix<T: Equatable, "Summable", "Multipliable">
问题1: 我可以使用什么协议名称?我该如何实现?
在相关说明中,要使用’+’运算符添加加法能力,我应该声明一个这样的函数(这也适用于乘法):
@infix func + (m1: Matrix<T>, m2: Matrix<T>) -> Matrix<T> {
// perform addition here and return a new matrix
return result
}
但是,此代码不被Xcode接受。更具体地说,这) -> Matrix<T> {
会产生错误:Use of undeclared type 'T'
。我的意思<T>
是,结果将是一个具有与两个输入矩阵相同类型的矩阵,但是我可能完全弄乱了语法。
问题2: 如何为加法结果提供类型信息?
这是您的第二个问题(但您确实应该问两个单独的问题):
@infix func + <T> (m1: Matrix<T>, m2: Matrix<T>) -> Matrix<T> { ... }
对于您的第一个问题:在解决之前,这是为类型参数定义多个约束的语法:
struct Matrix<T where T: Equatable, T: Summable, T: Multipliable> {...}
或者,如GoZoner在评论中所写:
struct Matrix<T: protocol<Equatable, Summable, Multipliable>> {...}
但是我们将不需要它。首先,定义一个新协议并列出所需的操作。您甚至可以扩展它Equatable
:
protocol SummableMultipliable: Equatable {
func +(lhs: Self, rhs: Self) -> Self
func *(lhs: Self, rhs: Self) -> Self
}
然后,提供要遵循的类型的扩展名。在这里,对于Int
和Double
,扩展甚至是空的,因为内置了所需操作的实现:
extension Int: SummableMultipliable {}
extension Double: SummableMultipliable {}
然后,在type参数上声明您的类型约束:
struct Matrix<T: SummableMultipliable> { ... }
最后,您可以编写如下内容:
let intMat = Matrix<Int>(rows: 3, columns: 3, initialValue: 0)
let doubleMat = Matrix<Double>(rows: 3, columns: 3, initialValue: 0)
let i: Int = intMat[0,0]
let d: Double = doubleMat[0,0]
您需要做的最后一件事是在操作符的定义中插入类型约束:
@infix func + <T: SummableMultipliable> (m1: Matrix<T>, m2: Matrix<T>) -> Matrix<T> { ... }
考虑一个具有的API,如下所示: 很简单,只有页面大小和跳过计数属性。 此外,现在我还有一些类,它们也包含但未分页。 在我的测试中,我希望他们都能实现一个接口,这样我就可以用一些更基本的测试来生成一个通用的基本测试类。为此,我添加了我认为会起作用的内容: 我将PagedResults更改为: 错误 但现在编译器抱怨PagedResultBase继承的所有地方的使用情况(?)从。 但是,如果我将接口
问题内容: 我正在尝试使用泛型动态创建基于实例的类型,但是在类自省时遇到了困难。 这里是问题: 有一个Swift相当于Obj-C的吗? 有没有办法使用from 的结果实例化一个类? 有没有一种方法可以严格从通用参数获取信息或以其他方式键入信息?(类似于C#的语法) 问题答案: 那么,对于一个,雨燕等同的IS (见元类型的文档,但他们非常薄)。 实际上,它甚至都不起作用!您必须使用。 同样,我尝试了
问题内容: 如果在Java中创建泛型类(该类具有泛型类型参数),则可以使用泛型方法(该方法带有泛型类型参数)吗? 考虑以下示例: 正如您对通用方法所期望的那样,我可以使用任何对象调用的实例: 但是,如果我尝试使用 不 指定泛型类型的实例,则无论传入什么,我都会调用返回, 奇怪的是,如果返回类型是通用类,它将编译(例如(实际上,这可以解释-参见下面的答案)): 此外,如果输入通用类,即使仅使用通配符
如果在Java中创建泛型类(该类具有泛型类型参数),是否可以使用泛型方法(该方法采用泛型类型参数)? 考虑下面的例子: 正如您所期望的那样,对于任何对象,的实例,我都可以调用: 但是,如果我试图使用的实例而不指定泛型类型,那么调用将返回一个
在研究泛型时,我注意到泛型方法和泛型类型(类或接口)在类型引入语法上的一个差异使我感到困惑。 泛型方法的语法为 文件上说 为了彼此保持一致,我希望方法语法为 ,或者类型语法(for class)为,但事实显然并非如此。 为什么一个要介绍在前,另一个要介绍在后? 我主要以的形式使用泛型,并认为可能看起来很奇怪,但这是一个主观的参数,此外对于方法也是这样。您可以调用,类似于 在寻找技术解释时,我想在指
问题内容: 我正在为核心数据编写通用包装类。 这是我的一些基本类型。没什么特别的。 我已经将我的coredata写在协议中抽象化了。如果您让我知道您对我要提出的抽象的意见,我将不胜感激。但是在扩展中,我遇到了以下错误: 无法将类型“ NSFetchRequest”的值转换为预期的参数类型“ NSFetchRequest <_>” 不确定我该如何解决。我尝试了各种更改代码的尝试,但未成功…… 另外,