Block(代码段)封装了一段代码,能够在不论什么时候运行。

Block能够作为函数參数或者函数返回值,而其本身又能够带输入參数或返回值。它和传统的函数指针非常相似,可是有差别:block是inline(内联函数)的,而且默认情况下它对局部变量是仅仅读的。

苹果官方建议尽量多用block.在多线程、异步任务、集合遍历、集合排序、动画转场用的非常多。

Block的定义:

int (^MySum) (int, int) = ^(int a, int b){

return a + b;

}

定义了一个叫MySum的block对象,它带有两个int參数,返回int类型,等号右边是block的详细实现。

void test(){
//定义了一个block,这个block返回值是int类型,接收两个int类型參数
int (^Sum) (int, int) = ^(int a, int b){
return a + b;
}; int a = Sum(10, 11); NSLog(@"%i", a);
}
void test2(){
//block能够訪问局部变量。但默认情况下不能改动
int c = 15;
//使用__blockkeyword,变量能够在block中改动
__block int b = 25; MySum sum = ^(int a, int b){
NSLog(@"C is %i", c);
b = 35;
NSLog(@"B is %i", b);
return a + b;
}; NSLog(@"%i", sum(10, 10));
}

在上一篇中我们实现了一个button监听器。这一篇我们使用block来实现button监听器。

#import <Foundation/Foundation.h>
@class Button; typedef void (^ButtonBlock) (Button *); @interface Button : NSObject //这里临时用assign
@property (nonatomic, assign) ButtonBlock block; //模拟button点击
- (void)click; @end

在Button.h中我们定义了一个数据类型  void(^ButtonBlock) (Button *)。 然后定义一个该类型的成员变量 ButtonBlock block;

加入了一个成员方法 - (void)click;

#import "Button.h"

@implementation Button

- (void)click {
_block(self);
} @end

Button.m文件里实现了 - (void)click方法

int main(int argc, const char * argv[]) {
@autoreleasepool {
Button *btn = [[[Button alloc] init] autorelease]; btn.block = ^(Button *btn){
NSLog(@"button%@被点击了", btn);
};
//模拟button点击
[btn click];
}
return 0;
}

最后在主函数中我们先获取button对象,然后给button对象中的block对象赋值。最后在模拟button点击事件的触发。

细心的朋友可能会发现,这里定义的block和c语言中的指向函数的指针特别想。两个对照方下:

int sum1(int a, int b){
return a + b;
} void test3(){ //Block
int(^sum)(int, int) = ^(int a, int b){
return a + b;
}; //指向函数的指针
int (*sum1)(int, int) = sum1; //调用
sum(11, 11);
sum1(10, 10);
}
typedef int(^MySum) (int, int);
typedef int (*sum2)(int, int);

Objective-C基础笔记(6)Block的更多相关文章

  1. Java基础笔记 – Annotation注解的介绍和使用 自定义注解

    Java基础笔记 – Annotation注解的介绍和使用 自定义注解 本文由arthinking发表于5年前 | Java基础 | 评论数 7 |  被围观 25,969 views+ 1.Anno ...

  2. php代码审计基础笔记

    出处: 九零SEC连接:http://forum.90sec.org/forum.php?mod=viewthread&tid=8059 --------------------------- ...

  3. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  4. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  5. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  6. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

  7. MYSQL基础笔记(二)-SQL基本操作

    SQL基本操作 基本操作:CRUD,增删改查 将SQL的基本操作根据操作对象进行分类: 1.库操作 2.表操作 3.数据操作 库操作: 对数据库的增删改查 新增数据库: 基本语法: Create da ...

  8. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  9. JavaScript基础笔记二

    一.函数返回值1.什么是函数返回值    函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...

  10. JavaScript基础笔记一

    一.真假判断 真的:true.非零数字.非空字符串.非空对象 假的:false.数字零.空字符串.空对象.undefined 例: if(0){ alert(1) }else{ alert(2) } ...

随机推荐

  1. css中可继承和不可继承属性

    一.无继承性的属性 1.display:规定元素应该生成的框的类型 2.文本属性: vertical-align:垂直文本对齐 text-decoration:规定添加到文本的装饰 text-shad ...

  2. 错误处理: Python值传递和引用传递的问题

    1.插入数据库的时候报错110, 提示columns数量少于插入的值内容. 2.核对了下栏目并没有少,打印出插入的值,看看值是不是多了. 查看了下,确实第二次值的时候长度边长了,第二次把第一次的部分值 ...

  3. Difference between git remote add and git clone

    http://stackoverflow.com/questions/4855561/difference-between-git-remote-add-and-git-clone git remot ...

  4. iptables之ipset集群工具

    ipset介绍 ipset是iptables的扩展,它允许你创建 匹配整个地址集合的规则.而不像普通的iptables链只能单IP匹配, ip集合存储在带索引的数据结构中,这种结构即时集合比较大也可以 ...

  5. hibernate基础工具findBySQL学习

    public List<Map<String,Object>> findBySQL(String sql,Map<String,Object> param,int ...

  6. Codeforces 903E Swapping Characters

    题目大意 考虑一个未知的长为 $n$($2\le n\le 5000$)由小写英文字母构成的字符串 $s$ .给出 $k$($1\le k\le 2500$,$nk\le 5000$)个字符串 $s_ ...

  7. 【库存】NOI笔试习题集

    https://wenku.baidu.com/view/2dc9d10854270722192e453610661ed9ad5155ba.html

  8. touch event 存疑

    1.原声js与借用jquery输出来的事件列表却不一样 function touchPlay(e) { e.preventDefault(); console.log(e); } var screen ...

  9. Censoring(bzoj 3940)

    Description Farmer John has purchased a subscription to Good Hooveskeeping magazine for his cows, so ...

  10. Nginx配置https双向认证

    1.      前期的准备工作: 安装openssl和nginx的https模块 cd ~/ mkdir ssl cd ssl mkdir demoCA cd demoCA mkdir newcert ...