- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
给定一个 Color
对象数组,我希望能够根据条件将某种颜色提升到数组的顶部。假设每个 Color
都有一个 bool 值 isBright
属性,并且提升颜色的测试将是 $0.isBright
。我想推广第一个这样的颜色。
我会提供一种更通用的方法来根据不同的测试来提升颜色。我已经通过两种方法成功地实现了这一点,但我不确定哪种更好。如果我错误地命名或描述了这些技术,请原谅我。
private func promoteColor(from colors: inout [Color], where promote: ((Color) -> Bool)) {
if let index = colors.index(where: promote) {
let color = colors.remove(at: index)
colors.insert(color, at: 0)
}
}
// call site:
promoteColor(from: &colors, where: { $0.isBright })
extension Array where Element: Color {
mutating func promote(where promote: (Color) -> Bool) {
if let index = index(where: promote) {
let color = remove(at: index)
insert(color, at: 0)
}
}
}
// call site:
colors.promote(where: { $0.isBright })
我更喜欢选项 B 的可读性,但我不确定在决定使用哪一个时我还应该考虑什么。两者有什么优点或缺点吗?
我想选项 B 可以推广:
extension Array {
mutating func promote(where promote: (Element) -> Bool) {
if let index = index(where: promote) {
let element = remove(at: index)
insert(element, at: 0)
}
}
}
最佳答案
inout
应尽可能避免使用,尤其是当您具有可变函数时。
您最好的简单选择可能是:
extension Array {
mutating func promote(where predicate: (Element) -> Bool) {
if let index = index(where: predicate) {
let element = remove(at: index)
insert(element, at: 0)
}
}
}
这是我昨晚想到的另一个小更新。如果您想要更高的性能。
第二个版本将避免在提升的元素之后额外移动元素。我还测试了它,其中提升的元素是第一个元素,并且使用此逻辑是安全的。
extension Array {
mutating func promote(where predicate: (Element) -> Bool) {
if let index = index(where: predicate) {
withUnsafeMutableBufferPointer { (bufferPointer: inout UnsafeMutableBufferPointer<Element>) -> Void in
let promotedElement = bufferPointer[index]
for i in (0..<index).reversed() {
bufferPointer[i + 1] = bufferPointer[i]
}
bufferPointer[0] = promotedElement
}
}
}
}
关于swift - 改变数组扩展与 inout 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49992468/
这并不是要实际创建一个带有 inout 端口的 verilog 模块。我发现了很多关于这个的帖子。 我坚持的是,如果我有一个带有输入端口的黑盒模块,假设它的定义如下 module blackbox(i
我有两段代码 func renderer(_ renderer: SCNSceneRenderer, didAdd node: SCNNode, for anchor: ARAnchor) { /
我的 TableViewController 类中有这个奇怪的错误消息 class MenuTableViewController: UITableViewController { filepriva
这行 var machine = [CChar](_unsafeUninitializedCapacity: size, initializingWith: 0) 抛出错误。 错误信息: Cannot
我正在制作一个应用程序,当您按下一个表示紧急的按钮时,会有一个标签显示“紧急”。就在我实现与按钮的用户交互之前,我有一个数组(如下所示),其中一些对象具有 urgent = true,但有些对象具有
1、MySQL 存储过程参数(in) MySQL 存储过程 “in” 参数:跟 C 语言的函数参数的值传递类似, MySQL 存储过程内部可能会修改此参数,但对 in 类型参数的修改,
我知道 inout 参数是什么以及如何使用它们。假设我们有一个 inout 参数 io并希望创建一个双向静态 RAM,例如以下代码: LIBRARY ieee; USE ieee.std_logic_
我认为 inout 让你传入一个引用(准确吗?),然后如果引用被多次更改,就像你可能对数组所做的那样,那么数组就不必复制很多次,因为它现在是一个引用类型? 最佳答案 swift 中输入输出参数的语义不
如果为两个参数传递相同的变量会出错。谁能解释为什么我们不能在输入参数函数中传递相同的变量,而我们可以在普通函数中传递 func swapTwoInts(a: inout Int, b: inout I
我正在 Swift 中迈出第一步,并解决了第一个问题。我正在尝试在具有约束的通用函数上使用 inout 通过引用传递数组。 首先,我的申请起点: import Foundation let sort
我想用 T 变量简化这段代码,但无法编译成功。希望你能给我指路。 这是我要重写的“重复”代码: func getIntegerValue (listValues: [Any], numValu
我有三个类 A、B 和 C。A 有一个名为 rA 的资源。我想要实现的是所有这些实例都引用了完全相同的资源。 所以用 Swift 术语具体来说: A 类有一个名为 foo 的属性: private v
我有一个像下面这样的函数,但是当我执行它时,它显示“Escaping closure captures 'inout' parameter 'cani'”我错过了什么? func duration(o
在一个对象中,我有一个指向另一个特定类的某个对象的常量句柄数组。在一个方法中,我可能想将其中一个句柄作为 inout 返回。 -范围。这里作为一个简化的例子: class A {} class B {
我知道什么inout用于值类型。 对于对象或任何其他引用类型,在这种情况下该关键字是否有用途,而不是使用 var ? 代码示例: private class MyClass { private
标题可能有点令人困惑,所以让我向您解释一下。 在 Swift 中,我们可以拥有带有默认参数值的函数,例如: func foo(value: Int = 32) { } 我们也可以有 In-Out 参数
在书籍中搜索了一段时间后,在这里有关于stackoverflow的文章,也有关于一般网络的文章,我发现很难找到对fortran参数意图之间真正差异的简单解释。我了解的方式是这样的: intent(in
优良作法规定,Fortran中的子例程参数应各自具有指定的意图(即this question所述的intent(in),intent(out)或intent(inout)): subroutine b
拥有什么实际区别 subroutine fillName(person) type(PersonType), intent(inout) :: person person%name = "
我从 Chisel 3 源代码生成 Verilog,并使用 UCF 文件将 Verilog 的顶部模块端口映射到 FPGA 引脚。 我的设计中有一组输入输出引脚(SDRAM 数据引脚),它们在 Chi
我是一名优秀的程序员,十分优秀!