Block系列1:初识block
//-------1、定义函数----- //1、函数
int sum(int a,int b)
{
return a+b;
}
//------------------2、声明--------- //2、声明函数指针【将sum换成*p就能够了】
int (*p)(int a,int b); //(1)声明block【将sum换成^myBlock就能够了】
int (^myBlock)(int a,int b); //举一反三
void (^myBlock2)(void);
- (void)viewDidLoad
{
[super viewDidLoad]; //---------------------3、赋值【不同之处】------------------
// 3、给函数指针赋值
p = sum;
//(2)将函数赋值给myBlock【^后面加參数列表,以及代码块内容,并以“;”结束】
myBlock = ^(int a,int b)
{
return a+b;
}; //---------------------4、调用------------------
//4、调用
int result = p(3,6);
NSLog(@"%d",result);
//(3)调用
int resultBlock = myBlock(3,6);
NSLog(@"%d",resultBlock); myBlock2 = ^(void)
{
NSLog(@"myBlock2运行了");
}; myBlock2(); //---------------------二、文件之间传值------------------
//block的调用
Person *person = [[Person alloc]init];
//1-2实现block
// ^int(int a, int b) {
// return a+b;
// }
//把person的10和20传到本文件里
//局部变量到block中是常量。如需改变值则须要在声明前面加 __block
__block int number = 10; int resultPs = [person testMethod:^int(int a, int b) {
number = 20;
return a+b+number;
}];
//typedef 方式创建
int resultPs2 = [person testMethod2:^int(int a, int b) {
return a+b;
}];
NSLog(@"resultPs:%d resultPs2:%d",resultPs,resultPs2); } @end
Person.h
#import <Foundation/Foundation.h>
//这里的PersonBlock是类型名字,能够理解为int
typedef int(^PersonBlock) (int a,int b);
@interface Person : NSObject //1-1在參数中声明【int(^)(int a, int b】
- (int)testMethod:( int(^)(int a, int b) )block;
//这里不须要加星号
- (int)testMethod2:(PersonBlock)block;
@end
Person.m
#import "Person.h" @implementation Person
//1-3调用block
- (int)testMethod:( int(^)(int a, int b) )block
{
return block(10,20);
} - (int)testMethod2:(PersonBlock)block
{
return block(1,2);
}
@end
Block系列1:初识block的更多相关文章
- Block系列2:Block内存管理
ViewController.h #import <UIKit/UIKit.h> @interface ViewController : UIViewController { UIImag ...
- 初识block
我们可以把Block当做Objective-C的匿名函数.Block允许开发者在两个对象之间将任意的语句当做数据进行传递,往往这要比引用定义在别处的函数直观.另外,block的实现具有封闭性(clos ...
- 写给喜欢用Block的朋友(ios Block)
作者:fengsh998原文地址:http://blog.csdn.net/fengsh998/article/details/38090205转载请注明出处如果觉得文章对你有所帮助,请通过留言或关注 ...
- block的用法以及block和delegate的比较(转发)
看到一篇写的关于block和delegate放在一起来方便大家理解的文章,感觉不错,就推荐给大家来看一下. 代理设计模式对于iOS开发的人来说肯定很熟悉了,代理delegate就是委托另一个对象来帮忙 ...
- Objective-C中Block语法、Block使用以及通过Block实现数组排序
Block:语法块,本质上是匿名函数(没有名称的函数) 标准C里面没有Block,C语言的后期扩展版本,加入了匿名函数 在C++.JS.Swift等语言有类似语法,叫做闭包 Block语法和C语言里的 ...
- WCF编程系列(一)初识WCF
WCF编程系列(一)初识WCF Windows Communication Foundation(WCF)是微软为构建面向服务的应用程序所提供的统一编程模型.WCF的基本概念: 地址:定义服务的 ...
- iOS开发:使用Block在两个界面之间传值(Block高级用法:Block传值)
iOS开发:使用Block在两个界面之间传值(Block高级用法:Block传值) 使用Block的地方很多,其中传值只是其中的一小部分,下面介绍Block在两个界面之间的传值: 先说一下思想: ...
- Block高级用法:Block传值UI_12(3)
1.简单复习Block的定义.赋值.调用做学习传值铺垫: //声明一个函数 无返无参void printfHello(int a);//函数的实现void printfHello(int a){ ...
- 文件系统的block 数据库中的block 以及内存中的page基础知识汇总(自己理解 可能有误)
1. 操作系统文件系统中的的block 文件系统中的block 是文件系统最小的读写单元,在HDD的磁盘时代, 一般block的大小可能与磁盘的扇区大小一致为 512bytes 也因为这个原因MBR启 ...
- ORA-01578 ORACLE data block corrupted (file # 29, block # 2889087)
BW数据库后台报错如下:F:\oracle\SBP\saptrace\diag\rdbms\sbp\sbp\trace ORA-01578: ORACLE data block corrupted ( ...
随机推荐
- Golang遇到的问题记录
1,windows cmd 结束输入问题 func main() { counts := make(map[string]int) countLines(os.Stdin, counts) fmt.P ...
- [LOJ#2255][BZOJ5017][Snoi2017]炸弹
[LOJ#2255][BZOJ5017][Snoi2017]炸弹 试题描述 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸时,如果另一个炸弹所在位置 Xj 满足: ...
- 刷题总结——字符串(ssoj)
题目: 给定n个小的字符串T和一个大的字符串S,先输出T总共再S中出现了多少次 然后q个询问···每次修改S上的一个字母,然后再次输出上述答案··· n小于1000,q<200000,T的总长度 ...
- 学习orm框架及一些看法
首先说说我对现在主流的ORM框架的一些看法: 优点: 让程序员不再关注数据库细节,专心在业务逻辑上,程序员可以不懂数据库就可以开发系统. 让数据库迁移变的非常方便,如果系统需要更改使用的数据库,直接改 ...
- CF985F Isomorphic Strings (字符串Hash,巧解)
题目链接 题意翻译 给你一个长度为 \(n\) 的字符串,\(m\) 次询问. 问两个相同长度的子串是否匹配. 我们称两个子串是匹配的,当且仅当其满足: 其中一个子串的字母可替代另一个子串的字母 例如 ...
- docker 查询或获取私有仓库(registry)中的镜像
docker 查询或获取私有仓库(registry)中的镜像,使用 docker search 192.168.1.8:5000 命令经测试不好使. 解决: 1.获取仓库类的镜像: [root@sha ...
- 使用docker Maven插件本地构建docker镜像并发布到远程服务器
1.登录网站https://start.spring.io/,生成一个基本的SpringBoot应用. 2.将应用导入Eclipse IDE并创建Application类.目录结构如下: Applic ...
- zoj 3790 Consecutive Blocks 离散化+二分
There are N (1 ≤ N ≤ 105) colored blocks (numbered 1 to N from left to right) which are lined up in ...
- luoguP1040 区间DP(记忆化 加分二叉树
dp[l][r]记录中序序列为l, l+1..r的最大加分值 root[l][r]记录这个序列的根节点 转移 i 为根节点 dp[l][r] = max(dp[l][i-1]*dp[l+1][r]+a ...
- 【CF1016B】Segment Occurrences(模拟)
题意:给定两个串s和t,多次询问s的一个区间[l ,r]中有多少个子串与t串相同 len<=1e3,q<=1e5 思路:前缀和 #include<cstdio> #includ ...