我有一个音频播放器的全局变量。 try word放在变量初始化之前有什么区别
do{
try audioPlayer = AVAudioPlayer(contentsOf: audioURL)
}catch {}
在调用构造函数之前放置try
do{
audioPlayer = try AVAudioPlayer(contentsOf: audioURL)
}catch {}
当然上面两种情况没有任何编译错误。 谢谢
最佳答案
没有实际区别。作为said by the language guide (强调我的):
When the expression on the left hand side of a binary operator is marked with
try,try?, ortry!, that operator applies to the whole binary expression. That said, you can use parentheses to be explicit about the scope of the operator’s application.// try applies to both function calls sum = try someThrowingFunction() + anotherThrowingFunction() // try applies to both function calls sum = try (someThrowingFunction() + anotherThrowingFunction()) // Error: try applies only to the first function call sum = (try someThrowingFunction()) + anotherThrowingFunction()
就像+ , 赋值也是一个二元运算符。因此,当你说
do{
try audioPlayer = AVAudioPlayer(contentsOf: audioURL)
}catch {}
try适用于两个 表达式 audioPlayer和 AVAudioPlayer(contentsOf: audioURL) .孤独的表情audioPlayer 不可能在这里抛出错误——因此 try在这种情况下仅适用于对 AVAudioPlayer 的调用的 init(contentsOf:) ,可以抛出。
推导of the grammar这是:
// "try" "audioPlayer" "= AVAudioPlayer(contentsOf: audioURL)"
expression → <b>try-operator<sub>opt</sub> prefix-expression binary-expressions<sub>opt</sub></b>
prefix-expression → prefix-operator<sub>opt</sub> postfix-expression
postfix-expression → primary-expression
primary-expression → identifier generic-argument-clause<sub>opt</sub>
identifier → // matches "audioPlayer" (I'm not going to fully derive this bit further)
binary-expressions → binary-expression binary-expressions<sub>opt</sub>
binary-expression → <b>assignment-operator</b> try-operator<sub>opt</sub> prefix-expression
prefix-expression → prefix-operator<sub>opt</sub> postfix-expression
postfix-expression → initializer-expression // matches AVAudioPlayer(contentsOf: audioURL)
当你说
do{
audioPlayer = try AVAudioPlayer(contentsOf: audioURL)
}catch {}
您使用的事实是赋值表达式 has the grammar of :
binary-expression → assignment-operator <b>try-operator<sub>opt</sub></b> prefix-expression
如您所见,try-operator 也可以出现在此处运算符的右侧,因此将应用于 prefix-expression – 在这种情况下是 AVAudioPlayer.init(contentsOf:) .
所以在这两种情况下,您都捕获了可能从 AVAudioPlayer.init(contentsOf:) 抛出的错误.第一个示例仅包含从运算符左侧的表达式中抛出错误的可能性,它不可能这样做。
使用你觉得更舒服的那个——我个人的喜好,以及与try的位置更一致的选项。在语言的其他地方,就是把try在右侧。
关于swift - "try"关键字的位置差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42693946/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
“输出”是一个序列化的OpenStruct。定义标题try(:output).try(:data).try(:title)结束什么会更好?:) 最佳答案 或者只是这样:deftitleoutput.data.titlerescuenilend 关于ruby-on-rails-更好的替代方法try(:output).try(:data).try(:name)?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c