Block 是 带有自动变量的匿名函数。

   emmmm 反正我看了也不懂,我们一点点用具体的例子分析一下block。

  1. 我们现在要在一个文件中使用block(我们后面再提到两个界面传值的block的例子)

   void (^ourblo)(void);

这样就声明了一个叫做 ourblo 的 block,但是他是空的。

符号 " ^ " 代表block,这个block的名字叫做 " ourblo "。(里面的几个void我们后面再说)

  我们有以下这个例子:

    void (^ourblo)(void) = ^(void){
NSLog(@"呵呵");
}; ourblo();

在这里我们给他赋了一个值(即 等号后面的内容)。

我们可以把它看作一个函数,这个函数的内容就是打印“呵呵”两个字。

在声明了这个block之后,我们直接用 ourblo() 的方式就可以使用它。

  2.现在我们需要使用一个,可以传值进去的block,我们把上面的代码稍微改一下,就可以得到下面这个:

    void (^ourblo)(NSString *str) = ^(NSString *str){
NSLog(@"%@", str);
}; NSString *myStr = @"呵呵呵"; ourblo(myStr);

注意看,我们把第一个例子里的 两个 void 都替换成了 NSString *str,这就是我们要传给这个函数的输入值。

这个时候,ourblo的功能就变成了,打印出我们传给它的字符串。

  3.继续,我们现在需要一个block帮我们判断,我们传入的字符串是不是“呵呵”:

    BOOL (^ourblo)(NSString *str) = ^(NSString *str){
if ([str isEqualToString:@"呵呵"]) {
//字符串是“呵呵”
return YES;
} else {
return NO;
}
}; NSString *myStr = @"呵呵"; BOOL isHeHe = ourblo(myStr);

我们把剩余的最后一个 void 改成 BOOL ,这就是我们想得到的这个函数输出的值的类型。

这个例子里,函数就满足了我们上面说的这个功能。是“呵呵”的时候他会返回 YES,不是的时候会返回 NO。

  4.在上面的例子里,我们把block当作函数去理解。不过 block 是可以被赋值的,比如下面这样:

    BOOL (^ourblo)(NSString *str);//这句代码 初始化 ourblo

    ourblo = ^(NSString *str) {
if ([str isEqualToString:@"呵呵"]) {
return YES;
} else {
return NO;
}
}; NSString *myStr = @"呵呵"; BOOL isHeHe = ourblo(myStr); // 对 ourblo 重新赋值
ourblo = ^(NSString *str) {
return NO;
}; BOOL isHeHe2 = ourblo(myStr); NSLog(@"%@,%@",@(isHeHe), @(isHeHe2));

我们对 ourblo 进行重新赋值,会看到最后打印出来的结果是 1 , 0

即一个 YES,一个 NO,说明重新赋值之后,再使用 ourblo时,它的逻辑确实被修改了。

  5.在另一篇里讲了如何通过 block 实现两个页面的传值和交互。

https://www.cnblogs.com/OranBlog/p/5861826.html

其实,它的原理可以看作,B中定义的“函数”,在 A 中被赋值,然后被B调用。

[OC] Block 是什么的更多相关文章

  1. Swift3.0 函数闭包与OC Block

    刚接触Swift,如有不对的点,欢迎指正.转载请说明出处 定义一个基本函数 //定义一个函数,接收一个字符串,返回一个String类型的值 func test(name:String) -> S ...

  2. OC Block网上转载

    1.block是一个特殊的OC对象, 它建立在栈上, 而不是堆上, 这么做一个是为性能考虑,还有就是方便访问局部变量. 2.默认情况下block使用到的局部变量都会被复制,而不是保留.所以它无法改变局 ...

  3. OC BLOCK和协议

    一.BOLCK (一)简介 BLOCK是什么?苹果推荐的类型,效率高,在运行中保存代码.用来封装和保存代码,有点像函数,BLOCK可以在任何时候执行. block实际上是: 指向结构体的指针 BOLC ...

  4. OC block的简单使用

    http://blog.csdn.net/itpeng523/article/details/23965147 一.先用Xcode创建一个空工程 学习block之前先用弄懂c语言的函数指针 看代码: ...

  5. iOS - OC Block 代码块

    前言 Block 是一段预先准备好的代码,可以在需要的时候执行,可以当作参数传递.Block 可以作为函数参数或者函数的返回值,而其本身又可以带输入参数或返回值.Block 是 C 语言的,类似于一个 ...

  6. oc block基本使用

    // // main.m // block基本使用 // // Created by Ymmmsick on 15/7/21. // Copyright (c) 2015年 Ymmmsick. All ...

  7. [OC] Block的使用

    由ControllerA跳转到controllerB,在controllerB中选择一个参数的值,并将它传回给controllerA. 首先,在controllerB的.h文件中写入: @interf ...

  8. OC Block(代码块)

    #import "ViewController.h" @interface ViewController () @end @implementation ViewControlle ...

  9. OC block声明和使用

    #import "Button.h" typedef int (^MySum) (int, int); void test() { // 定义了一个block,这个block返回值 ...

  10. oc block 遍历数组及字典

    原遍历数组NSArray * lines = ...for (NSString * line in lines) { // ...}for (int i = 0; i < lines.count ...

随机推荐

  1. 【单片机】nRF52832 实现停止蓝牙广播接口

    前言 有一个项目使用了 nRF52832 芯片作为主控,其中有用到蓝牙功能.在对蓝牙接口进一步封装的时候,发现 SDK 居然没有停止广播的接口,咨询了代理 FAE,对方也没有找到关闭广播的接口.后来通 ...

  2. Idea未识别maven项目

    https://blog.csdn.net/qq_41460654/article/details/120539509

  3. Vue 04 谷歌浏览器配置vue开发者工具

    参考链接:https://blog.csdn.net/wswq2505655377/article/details/111476799 1 插件下载 由于国内打不开谷歌商店,直接从网盘下载 链接:ht ...

  4. h5与原生app通信的各种功能

    import config from '@/config/index'; import cubeModule from '_public/CubeModule.json'; const _MIDEA_ ...

  5. CF1638E Colorful Operations

    \(\text{Solution}\) \(\text{code}\) #include <cstdio> #include <iostream> #include <s ...

  6. LeetCode 39. 组合总和 40.组合总和II 131.分割回文串

    欢迎关注个人公众号:爱喝可可牛奶 LeetCode 39. 组合总和 40.组合总和II 131.分割回文串 LeetCode 39. 组合总和 分析 回溯可看成对二叉树节点进行组合枚举,分为横向和纵 ...

  7. 两个集合之间数据过滤linq

    //以下为前台多字段循环匹配if (!input.Filter.IsNullOrEmpty()) { var keysList = input.Filter.Split(" ".T ...

  8. Android:ViewModel

    什么是 ViewModel ViewModel 旨在以注重生命周期的方式存储和管理界面相关数据.ViewModel 让数据可在发生屏幕旋转等配置更改后继续留存. 上面一段话是截取自官方文档对 View ...

  9. 基于C++的OpenGL 05 之坐标系统

    1. 引言 本文基于C++语言,描述OpenGL的坐标系统 前置知识可参考: 基于C++的OpenGL 04 之变换 - 当时明月在曾照彩云归 - 博客园 (cnblogs.com) 笔者这里不过多描 ...

  10. Vue学习笔记之表单绑定

    1. 概述 1.1. 什么是数据的双向绑定 Vue.js是一个MV VM框架, 即数据双向绑定, 即当数据发生变化的时候, 视图也就发生变化, 当视图发生变化的时候,数据也会跟着同步变化.这也算是Vu ...