草庐IT

dispatch_block_t

全部标签

iOS 在 dispatch_async 中调用 animateWithDuration

我调用了一个网络API来获取结果。收到响应后,我想使用动画功能删除带有指示的“visualIndicatorView”(UIView)。Indication和View进入隐藏状态但不顺利。这是我的代码:dispatch_async(dispatch_get_main_queue()){UIView.animateWithDuration(2.0,animations:{()->Voidinself.activityIndicator.hidden=trueself.visualIndicatorView.hidden=trueself.activityIndicator.stopAni

swift - 在 swift3 中使用方法而不是 block 来初始化惰性变量

在swift3文档中。推荐通过以下两种方式使用lazy:1。直接初始化`lazyvarsomeViews:UILabel=UILabel()`2。用block初始化lazyvaroverlayView:UILabel={[unownedself]inletoverlayView=UILabel()overlayView.backgroundColor=self.backgroundColor.withAlphaComponent(0.90)overlayView.font=UIFont.boldSystemFont(ofSize:YFCalendarOverlaySize)overla

swift - 如果我实际上没有在我的完成 block 中引用 self,我应该使用 [weak self] 吗?

当我有一个引用我的类对象属性的完成block时,我使用[weakself]。但是,有时我有一个不引用任何属性的完成block,但类对象可能会消失并取消初始化。我应该使用[weakself]吗?当我这样做时,它通常会发出警告Variable'self'waswrittento,butneverread...doSomeFunction(){[weakself]in//Noreferencestoselfhere} 最佳答案 捕获变量,只有当你在内部使用它时才会发生,默认情况下闭包永远不会捕获变量(不像Java内部类总是捕获this),

ios - 使 getNotificationSettings 返回而不是使用完成 block

我有一个方法用于我正在开发的应用程序的多个位置。这是一种检查远程推送通知是否启用的方法。该方法返回一个值,但您可能知道currentUserNotificationSettings已被弃用,所以现在我正在使用getNotificationSettings。问题是第一个返回一个值,而最新的使用一个block。我仍然希望能够返回一个值以避免重构所有内容,所以我写了以下内容,但它失败了,我不明白为什么......这样可以吗?!publicstaticvarisRemoteEnabled:Bool{varnotificationSettings:UNNotificationSettings?l

swift - 没有 catch block 的 "do statement"是什么意思?

在阅读iOS12编程时,我遇到了几个示例代码,其中包含do语句,没有catchblock,像下面这样:do{letmars=UIImage(named:"Mars")!letsz=mars.sizeletr=UIGraphicsImageRenderer(size:CGSize(sz.width*2,sz.height),format:mars.imageRendererFormat)self.iv1.image=r.image{_inmars.draw(at:CGPoint(0,0))mars.draw(at:CGPoint(sz.width,0))}}//======do{letm

ios - block 是否保证局部变量将在 Swift 中被修改?

funcfoo()->Bool{varapiResult:Bool=falsemyAPI.bar(){(result:Bool)->Voidin//somelogicinblockandlocalvariableassignmentapiResult=result}returnapiResult}apiResult的值是否保证被传入的block更新?(本人是学习iOS的大学生,请大家多多指教) 最佳答案 您正在将闭包(block)传递给myAPI.bar函数。该函数可能会也可能不会调用闭包。如果调用闭包,则apiResult会发生变

swift - 在分派(dispatch)异步中包装完成处理程序的语法

我有一个需要分配给属性的完成处理程序,但我希望它异步执行。如果我没有那个要求,我会写:request.completionBlock=completionBlock但是既然有这个需求,我就得这样写request.completionBlock={response,errorinDispatchQueue.main.async{completionBlock(response,error)}}这似乎是多余的和不敏捷的。有没有更简单的语法?我想写类似的东西request.completionBlock=completionBlock.map(DispatchQueue.main.async

swift - 我应该使用未命名的 Timer 还是 Dispatch asyncAfter 来延迟 1 次?

我可以通过两种方式延迟某些事情(也许还有更多方式):funcdelay(delay:Double,closure:@escaping()->()){DispatchQueue.main.asyncAfter(deadline:DispatchTime.now()+Double(Int64(delay*Double(NSEC_PER_SEC)))/Double(NSEC_PER_SEC),execute:closure)}//way1:delay(delay:1.0,closure:{})//way2:_=Timer.scheduledTimer(withTimeInterval:1.0

string - Swift 是否支持字符串 block ?

Ruby、Python等语言都支持字符串block。如:a='''HelloWorld'''Swift支持字符串block吗? 最佳答案 没有。如Swift编程语言介绍的词法结构中所述,stringliterals包含在一对引号中,并且不得包含换行符。语法规定:string-literal→"quoted-text"quoted-text→quoted-text-itemquoted-textoptquoted-text-item→escaped-characterquoted-text-item→(expression)quote

swift - 如何在 Swift 中为 `dispatch_function_t` 声明 `dispatch_async_f`?

Xcode7beta5。我正在尝试使用dispatch_async_f来避免阻塞。funcmyFirstFunc(){letidentifier=QOS_CLASS_BACKGROUNDletqueue=dispatch_get_global_queue(identifier,0)letcontext:UnsafeMutablePointer=nilletwork:dispatch_function_t=myOtherFuncdispatch_async_f(queue,context,work)}funcmyOtherFunc(context:UnsafeMutablePointer