草庐IT

dncp_block_verification

全部标签

ios - 在 Swift 中创建 block 不起作用

我正在尝试在Swift中创建block。我已经创建了类并像这样声明了blocktypealiasJSONParserBlock=(dict:NSDictionary?,error:NSError?)->Void变量声明:varblock:JSONParserBlock!和功能:funcGetdata(WebService:String,RequsetedParameterParam:NSDictionary?,BLOCK:JSONParserBlock!)->Void{}但我的问题是当我从另一个类调用这个函数时,这个函数没有执行函数调用是这样的:varobjJsonParser:Jso

ios - CATiledLayer 显示以前的图 block

当使CATiledLayer支持的View失效时,先前的图block仍然“卡住”并且未正确失效。这似乎发生在View无效时(在主线程上),而与此同时,图block渲染线程仍在处理以前版本的图block。不是缓存新版本的磁贴,而是缓存以前的版本。CATiledLayer支持的View是UIScrollView的subview并且是可缩放的。瓦片的渲染可能会很昂贵,并且可以使用渲染线程10毫秒。例子演示此问题的示例代码:https://github.com/Q42/CATiledLayerBug在CATiledLayer中,开始渲染所有红色方block(这大约需要3秒才能完成)每个渲染步骤

ios - 完成 block 中的 UIView 动画以位移开始

我使用UIView.animate编写了一个包含两个动画的简单动画链,但是完成block中的第二个动画并不完全从第一个动画开始的位置开始,所以我在右边有奇怪的位移。有人可以帮忙吗?也许我没有完全理解tranfrom属性。UIView.animate(withDuration:3,animations:{self.redView.transform=self.redView.transform.translatedBy(x:100,y:0)}){(_)inUIView.animate(withDuration:2,animations:{self.redView.transform=se

ios - 当我在 block 中使用 self 时,我得到一个 nil。但是 self 没有释放

我使用继承BaseViewController的viewController。在BaseViewController的方法“viewDidLoad”中调用函数“monitorNetworkStatus()”。privatefuncmonitorNetworkStatus(){ReachabilityManager.shared.startMonitoring{[weakself](status,presentingVC)inprint(self?.description)}}ReachabilityManager是单例的。startMonitoring函数是这样的funcstartMo

objective-c - 当我不需要使用完成 block 时,如何在 swift 中声明 NULL/Void?

这是objective-c中的代码:[selfpresentViewController:logInViewControlleranimated:YEScompletion:NULL];到目前为止,我的代码在swift中:self.presentViewController(logInViewController,animated:true,completion:)认为它会像输入“Void”一样简单。不幸的是,还有更多内容。 最佳答案 Apple的预发布文档说:funcpresentViewController(_viewContr

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会发生变