AAAA block

[self AAAA:^(BOOL isSuccessed, id userInfo, NSString *errorMsg) {

NSLog(@"AAAA: %d, userInfo: %@ errorMsg: %@", isSuccessed, userInfo, errorMsg);

}];

-(void)AAAA:(void(^)(BOOL isSuccessed,id userInfo,NSString *errorMsg))callback

{

__block NSMutableDictionary *_info = [@{} mutableCopy];

[self a001:

^(BOOL isSuccessed, id userInfo, NSString *errorMsg) {

NSLog(@"a001");

if (isSuccessed) {

[_info setObject:userInfo forKey:@"001info"];

}

else

{

[_info setObject:errorMsg forKey:@"001info"];

}

[self a002:^(BOOL isSuccessed, id userInfo, NSString *errorMsg) {

NSLog(@"a002");

if (isSuccessed) {

[_info setObject:userInfo forKey:@"002info"];

}

else

{

[_info setObject:errorMsg forKey:@"002info"];

}

[self a003:^(BOOL isSuccessed, id userInfo, NSString *errorMsg) {

NSLog(@"a003");

if (isSuccessed) {

[_info setObject:userInfo forKey:@"003info"];

}

else

{

[_info setObject:errorMsg forKey:@"003info"];

}

if (callback) {

callback(YES,@"userInfo", @"errorMsg");

}

}];

}];

}];

}

-(void)a001:(void(^)(BOOL isSuccessed,id userInfo,NSString *errorMsg))callback

{

NSLog(@"a001 inner");

if (callback) {

callback(YES,@"userInfo", @"errorMsg");

}

}

-(void)a002:(void(^)(BOOL isSuccessed,id userInfo,NSString *errorMsg))callback

{

NSLog(@"a002 inner");

if (callback) {

callback(YES,@"userInfo", @"errorMsg");

}

}

-(void)a003:(void(^)(BOOL isSuccessed,id userInfo,NSString *errorMsg))callback

{

NSLog(@"a003 inner");

if (callback) {

callback(NO,@"userInfo", @"errorMsg");

}

}

时间: 2024-10-05 13:13:23

AAAA block的相关文章

I.MX6 Linux udev porting

/*********************************************************************** * I.MX6 Linux udev porting * 声明: * 在嵌入式产品上,我们可以使用mdev来解决热插拔的问题,同时也经常看到 * udev,所以尝试来移植一下,但是最终发现她会丢失内核阶段产生的uevent, * 这导致无法生成内核阶段产生的设备节点,目前采用了mdev来做完成内核阶段的 * 设备节点生成,之后使用udev完成热插拔,这

block相关知识点

Block简介1.Block类似于函数,指向一块代码的指针(类似C中的回调函数)Block经常用来代替delegate2.跟函数的写法基本是一致的  声明 + 实现 + 调用    2.1声明:^ 脱字符                    返回类型(^Block的名字)(类型1 参数1,类型2 参数2……):    2.2 实现:Block的名字 = ^(类型1 参数1……){  }   2.3 调用:如果不调用,那么代码块中的内容是不会执行的,什么时候调用,就什么时候执行         

oracle block corrupt 坏块

整体上来讲,oracle的坏块能够分为两种情景:物理损坏和逻辑损坏.物理损坏是因为存储等原因造成的,致使oracle在处理数据块时发现块的checksum不一致.逻辑损坏多是因为oracle的bug或者内存错误引起,通过检測数据块的checksum并不会发现什么问题,可是在逻辑上这些块已经发生了损坏. oracle通过两个參数来控制对物理损坏和逻辑损坏的检測: SQL> show parameter db_block_check NAME TYPE VALUE -----------------

iOS block从零开始

iOS block从零开始 在iOS4.0之后,block横空出世,它本身封装了一段代码并将这段代码当做变量,通过block()的方式进行回调. block的结构 先来一段简单的代码看看: void (^myBlock)(int a) = ^(int a){ NSLog(@"%zd",a); }; NSLog(@"旭宝爱吃鱼"); myBlock(999); 输出结果: 2016-05-03 11:27:18.571 block[5340:706252] 旭宝爱吃鱼

嵌入式&iOS:回调函数(C)与block(OC)传 参/函数 对比

C的回调函数: callBack.h 1).声明一个doSomeThingCount函数,参数为一个(无返回值,1个int参数的)函数. void DSTCount(void(*CallBack)(int data_i32)); callBack.c 1).在doSomeThingCount函数,对运行次数自增,并调用参数--函数. void DSTCount(void(*CallBack)(int data_i32)) { static int numb = 0; numb++; (*Call

iOS学习之代码块(Block)

代码块(Block) (1)主要作用:将一段代码保存起来,在需要的地方调用即可. (2)全局变量在代码块中的使用: 全局变量可以在代码块中使用,同时也可以被改变,代码片段如下: 1 int local = 1;//注意:全局变量 2 void (^block0)(void) = ^(void){ 3 local ++; 4 NSLog(@"local = %d",local); 5 }; 6 block0(); 7 NSLog(@"外部 local = %d",lo

Block内存管理实例分析

在ios开发中,相信说道block大家都不陌生,内存管理问题也是开发者最头疼的问题,网上很多讲block的博客,但大都是理论性多点,今天结合一些实例来讲解下. 存储域 首先和大家聊聊block的存储域,根据block在内存中的位置,block被分为三种类型: NSGlobalBlock NSStackBlock NSMallocBlock 从字面意思上大家也可以看出来 NSGlobalBlock是位于全局区的block,它是设置在程序的数据区域(.data区)中. NSStackBlock是位于

Block

OC语言BLOCK和协议 一.BOLCK (一)简介 BLOCK是什么?苹果推荐的类型,效率高,在运行中保存代码.用来封装和保存代码,有点像函数,BLOCK可以在任何时候执行. BOLCK和函数的相似性:(1)可以保存代码(2)有返回值(3)有形参(4)调用方式一样. 标识符 ^ (二)基本使用 (1)定义BLOCK变量 Int (^SumBlock)(int,int);//有参数,返回值类型为int Void (^MyBlock)()://无参数,返回值类型为空 (2)利用block封装代码

iOS Block循环引用

前言 本篇文章精讲iOS开发中使用Block时一定要注意内存管理问题,很容易造成循环引用.本篇文章的目标是帮助大家快速掌握使用block的技巧. 我相信大家都觉得使用block给开发带来了多大的便利,但是有很多开发者对block内存管理掌握得不够好,导致经常出现循环引用的问题.对于新手来说,出现循环引用时,是很难去查找的,因此通过Leaks不一定能检测出来,更重要的还是要靠自己的分析来推断出来. 声景一:Controller之间block传值 现在,我们声明两个控制器类,一个叫ViewContr