草庐IT

swift - 了解 Swift 的闭包类型要求

coder 2023-09-17 原文

我正在努力养成以 Swifty 方式而不是翻译 Obj-C 的方式做事的习惯。

我正在用 Parse 做一个项目,在获取一堆 Parse 对象后,我想先对它们进行排序,然后从中提取特定的属性。这就是我现在正在尝试的:

if let notifications = fetchedObjects as? [PFObject] {
    // This line tells me "Cannot invoke 'sorted' with an argument list of type '((_, _) -> _)'
    let sortedMessages: [String] = notifications.sorted { $0.createdAt.compare($1.createdAt) == .OrderedAscending }
}

PFObject 有一个 createdAt 属性声明如下:var createdAt: NSDate? {获取}

我在这里遗漏了什么会扰乱 Swift 的类型检查?

在找出上述错误后,这是我想要的:

if let notifications = fetchedObjects as? [PFObject] {
    let sortedMessages: [String] = notifications.sorted({ $0.createdAt.compare($1.createdAt) == .OrderedAscending }).map { $0["message"] }
}

在我看来,所有类型都应该清晰且匹配。

更新

我今天又回到了这里,让它工作了。我没有在我的原始帖子中写它,但昨天我确实尝试强制打开 createdAt 可选的:

if let notifications = fetchedObjects as? [PFObject] {
    // This line tells me "Cannot invoke 'sorted' with an argument list of type '((_, _) -> _)'
    let sortedMessages: [String] = notifications.sorted { $0.createdAt!.compare($1.createdAt!) == .OrderedAscending }
}

这给了我完全相同的错误。到目前为止,我在使用 Swift 时学到的一件事是,当它给出神秘的类型不匹配错误时,最好为每个变量显式添加类型声明——这通常会导致更具体的错误消息。所以,今天,我把上面的代码写成这样:

    if let notifications = objects as? [PFObject] {
        let sortedMessages: [String] = notifications.sorted { (lhs: PFObject, rhs: PFObject) -> Bool in
            return rhs.createdAt!.compare(lhs.createdAt!) == .OrderedAscending
            }.map { $0["message"] as! String }
    }

这似乎编译没有问题。但是如果我依赖类型推断:

    if let notifications = objects as? [PFObject] {
        let sortedMessages: [String] = notifications.sorted { lhs, rhs in
            return rhs.createdAt!.compare(lhs.createdAt!) == .OrderedAscending
            }.map { $0["message"] as! String }
    }

我在 map 上遇到错误:无法使用类型为“((_) -> _)”的参数列表调用“map”

在我看来是这样的:

if let notifications = objects as? [PFObject] {
    let sortedMessages: [String] = notifications.sorted { $0.createdAt!.compare($1.createdAt!) == .OrderedAscending }
       .map { $0["message"] as! String }
}

应该是有效的,但是 Swift 的类型推断还没有达到标准……(?)。我不愿意让自己摆脱困境并责怪语言,但在这种情况下看起来很合理。我错过了什么吗?

最佳答案

类型不完全匹配。 createdAt 是一个Optional,而compare 方法接受一个非可选的。此外,如果不知道下标 PFObject 返回什么,如果它像字典,我猜它是 AnyObject!AnyObject?,其中情况下,它需要进行类型转换,并且可能需要使用 ! 强制解包。以下代码将编译:

notifications.sorted {
    switch ($0.createdAt, $1.createdAt) {
    case (.Some(let first), .Some(let second)):
        return first.compare(second) == .OrderedAscending
    default: 
        return true
    }
}.map { $0["message"]! as String }

请注意,在 Swift 1.2 中,您需要使用 as! 而不是 as,因为这是一个不安全的转换(来自 AnyObjectString)。如果对象上的 message 有可能为 nil,您可能还需要某种回退:

.map { $0["message"] as? String ?? "Default message" }

关于swift - 了解 Swift 的闭包类型要求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29381084/

有关swift - 了解 Swift 的闭包类型要求的更多相关文章

  1. ruby - Infinity 和 NaN 的类型是什么? - 2

    我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串

  2. ruby - 检查方法参数的类型 - 2

    我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)

  3. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  4. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  5. ruby-on-rails - 在 Rails 开发环境中为 .ogv 文件设置 Mime 类型 - 2

    我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain

  6. ruby - 使用 postgres.app 在 rvm 下要求 pg 时出错 - 2

    我正在使用Postgres.app在OSX(10.8.3)上。我已经修改了我的PATH,以便应用程序的bin文件夹位于所有其他文件夹之前。Rammy:~phrogz$whichpg_config/Applications/Postgres.app/Contents/MacOS/bin/pg_config我已经安装了rvm并且可以毫无错误地安装pggem,但是当我需要它时我得到一个错误:Rammy:~phrogz$gem-v1.8.25Rammy:~phrogz$geminstallpgFetching:pg-0.15.1.gem(100%)Buildingnativeextension

  7. ruby-on-rails - 带有 Zeus 的 RSpec 3.1,我应该在 spec_helper 中要求 'rspec/rails' 吗? - 2

    使用rspec-rails3.0+,测试设置分为spec_helper和rails_helper我注意到生成的spec_helper不需要'rspec/rails'。这会导致zeus崩溃:spec_helper.rb:5:in`':undefinedmethod`configure'forRSpec:Module(NoMethodError)对thisissue最常见的回应是需要'rspec/rails'。但这是否会破坏仅使用spec_helper拆分rails规范和PORO规范的全部目的?或者这无关紧要,因为Zeus无论如何都会预加载Rails?我应该在我的spec_helper中做

  8. ruby - Ruby 中的闭包和 for 循环 - 2

    我是Ruby的新手,有些闭包逻辑让我感到困惑。考虑这段代码:array=[]foriin(1..5)array[5,5,5,5,5]这对我来说很有意义,因为i被绑定(bind)在循环之外,所以每次循环都会捕获相同的变量。使用每个block可以解决这个问题对我来说也很有意义:array=[](1..5).each{|i|array[1,2,3,4,5]...因为现在每次通过时都单独声明i。但现在我迷路了:为什么我不能通过引入一个中间变量来修复它?array=[]foriin1..5j=iarray[5,5,5,5,5]因为j每次循环都是新的,我认为每次循环都会捕获不同的变量。例如,这绝对

  9. ruby - 了解在 Ruby 中与 lambda 一起使用的 inject 行为 - 2

    我经常将预配置的lambda插入可枚举的方法中,例如“map”、“select”等。但是“注入(inject)”的行为似乎有所不同。例如与mult4=lambda{|item|item*4}然后(5..10).map&mult4给我[20,24,28,32,36,40]但是,如果我制作一个2参数lambda用于像这样的注入(inject),multL=lambda{|product,n|product*n}我想说(5..10).inject(2)&multL因为“inject”有一个可选的单个初始值参数,但这给了我......irb(main):027:0>(5..10).inject

  10. ruby-on-rails - 如何测试自己对 Ruby/ROR 的了解? - 2

    是否有self验证的问题列表。看着那个,我可以确定我知道。我应该复习一下。在学习的过程中,我列了一个这样的list,但它只包含我在某处听说过的项目。我需要一段时间才能找到新的东西。 最佳答案 以下是针对ruby​​和Rails的一些测试列表。证书名称:RubyonRails谁提供:oDeskIncorporation认证费用:免费网站:https://www.odesk.com/tests/985?pos=0证书名称:RubyonRails提供者:Techgig.com(TimesBusinessSolutionsLimited(T

随机推荐