并发的简单介绍2

1.我们会一直和分派队列打交道,所以请确保你完全理解了其背后的概念。下面有 3 种分 派队列:

  Main Queue

  这个队列在主线程上执行它的所有任务,Cocoa 和 Cocoa Touch 允许程序员在主线程 上调用一切 UI-related 方法。使用 dispatch_get_main_queue 函数检索到主队列的句柄。

  Concurrent Queues

  为了执行异步和同步任务,你可以在 GCD 中检索到这些队列。多个并发队列能够轻而 易举的并行执行多个任务,没有更多的线程管理,酷!使用 dispatch_get_global_queue 函数 检索一个并发队列的句柄。

  Serial Queues

  无论你提交同步或者异步任务,这些队列总是按照先入先出(FIFO)的原则来执行任 务,这就意味着它们一次执行一个 Block Object。然而,他们不在主线程上运行,所以对于 那些要按照严格顺序执行并不阻塞主线程的任务而言是一个完美的选择。使用 dispatch_queue_create 函数创建一个串行队列。一旦你使用完队列,必须使用 dispatch_release 函数释放它。

2.

  Block Object是通常在Objective-C中以方法形式出现的代码包。Block Objects和GCD 共同创建了一个和谐环境,在这个环境里你能在 iOS 和 Mac OS X 上发布高性能的多线程 APPs。Block Objects和GCD有什么特别的地方呢?你可能会问。很简单:编程中,你不需 要接触线程!所有你要做的事情就是把代码放进Block Objects然后要求GCD来为你小心执 行代码。

(注意:

block 对象与普通的函数最大的区别可能就是拷贝本地变量的值,然后在 block 对象 内部进行访问,并会保存这份拷贝,以供局部访问。如果这些变量在 block 对象外修改了,那么 block 对象仍然会保存它自己拷贝的那一份。在后面会进行更多相关介绍。

)

  GCD是与Block Objects一起工作的。当使用GCD执行任务时,你可以传递一个Block Object,它可以同步或者异步执行,取决于你在 GCD 中使用的方法。因此,你可以创建一 个Block Object负责下载一个作为参数传递到它的URL。单独的Block Object可以同步或者 异步应用于 APP 的任何地方,这个位置依赖于你想如何运行它。你不必使 Block Object 本 身同步或异步,你只要简单通过同步或者异步的 GCD 方法来调用它,它就会工作。

3.

  操作可以同步或者异步执行代码块。你可以手动管理操作或者是把它们放到操作队列 中,这个队列会促使并发以致于你不需要思考底层线程管理。要了解在 APP 上 同步或者异步执行任务时如何使用操作和操作队列,如何使用基础线程和计时器。

Cocoa 提供了 3 种不同的操作:

Block Operation 它们促使执行一个或多个 Block Objects.

Invocation Operations 允许你在另一个当前存在的对象中调用一个方法。

Plain Operations
这些都是需要被继承普通操作的类。将要执行的代码会被写入操作对象的主要方法中。

一个 APP 的主线程是处理 UI 事件的线程。如果你在主线程执行一个长时间运行的任 务,就要注意 APP 的 UI 会没有响应或者响应缓慢。为了避免这一点,你可以创建一个独立 线程和/或计时器,它们会分别执行各自的任务(即使是一个长时间运行的任务)同时又不 会阻塞主线程。

时间: 2024-10-13 18:20:43

并发的简单介绍2的相关文章

ab工具使用(测试平台的并发性能)简单介绍一下

Apache -- ab工具主要测试网站的(并发性能) 这个工具非常的强大. 基本语法 :   cmd>ab.exe –n 请求总次数  -c 并发数 请求页面的url    进入到ab.exe目录 举例:  cmd>ab.exe –n 10000 –c 100 http://localhost/test.php 简单test结果简单介绍一下: ab工具使用(测试平台的并发性能)简单介绍一下

并发的简单介绍

介绍: 当两个或两个以上的任务同时执行时就发生了并发. 即使只有一个CPU,现代操作系统也能够在同时执行多个任务.要实现这一点,需要给每个任务从CPU重分配一定的时间片 .例如,要在1秒内执行10个同样有限级的人物,操作系统会用10来平均分配1000毫秒,那么每个任务就会有100毫秒的CPU 时间. 随着技术进步,现在的CPU有不止一个内核,这就意味着CPU真正具备了同时执行多个任务的能力. Grand Central Dispatch(dispatch [派遣,分派]),简称GCD,是一个与B

plsql的环境与介绍:环境的搭建和plsql的简单介绍

PLSQL编程 1.环境的搭建 (1)创建一个存储表空间 SQL> conn /as sysdbaConnected. SQL> create tablespace plsql datafile '/u01/oracle/oradata/ORCL/plsql01.dbf' size 1G; Tablespace created. (2)创建PLSQL用户SQL> create user plsql identified by plsql default tablespace plsql;

漫游Kafka入门篇之简单介绍

原文地址:http://blog.csdn.net/honglei915/article/details/37564521 介绍 Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了普通消息系统的功能,但具有自己独特的设计.这个独特的设计是什么样的呢? 首先让我们看几个基本的消息系统术语: Kafka将消息以topic为单位进行归纳. 将向Kafka topic发布消息的程序成为producers. 将预订topics并消费消息的程序成为consumer. Kafka以集群的方式运行,

iOS开发多线程篇 09 —NSOperation简单介绍

iOS开发多线程篇—NSOperation简单介绍 一.NSOperation简介 1.简单说明 NSOperation的作?:配合使用NSOperation和NSOperationQueue也能实现多线程编程 NSOperation和NSOperationQueue实现多线程的具体步骤: (1)先将需要执行的操作封装到一个NSOperation对象中 (2)然后将NSOperation对象添加到NSOperationQueue中 (3)系统会?动将NSOperationQueue中的NSOpe

WebSocket简单介绍

Java后端WebSocket的Tomcat实现 一.WebSocket简单介绍 随着互联网的发展,传统的HTTP协议已经很难满足Web应用日益复杂的需求了.近年来,随着HTML5的诞生,WebSocket协议被提出,它实现了浏览器与服务器的全双工通信,扩展了浏览器与服务端的通信功能,使服务端也能主动向客户端发送数据. 我们知道,传统的HTTP协议是无状态的,每次请求(request)都要由客户端(如 浏览器)主动发起,服务端进行处理后返回response结果,而服务端很难主动向客户端发送数据:

iOS开发多线程篇—多线程简单介绍

iOS开发多线程篇—多线程简单介绍 一.进程和线程 1.什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 比如同时打开QQ.Xcode,系统就会分别启动2个进程 通过“活动监视器”可以查看Mac系统中所开启的进程 2.什么是线程 1个进程要想执行任务,必须得有线程(每1个进程至少要有1条线程) 线程是进程的基本执行单元,一个进程(程序)的所有任务都在线程中执行 比如使用酷狗播放音乐.使用迅雷下载电影,都需要在线程中执行 3.线程

iOS开发多线程篇—NSOperation简单介绍

iOS开发多线程篇—NSOperation简单介绍 一.NSOperation简介 1.简单说明 NSOperation的作?:配合使用NSOperation和NSOperationQueue也能实现多线程编程 NSOperation和NSOperationQueue实现多线程的具体步骤: (1)先将需要执行的操作封装到一个NSOperation对象中 (2)然后将NSOperation对象添加到NSOperationQueue中 (3)系统会?动将NSOperationQueue中的NSOpe

MongoDB(一)——简单介绍

这两天简单学习了一下MongoDB数据库,属于NoSQL类型数据库的一种,先简单宏观的看一下NoSQL的相关知识和MongoDB的基础知识. NoSQL是Not Only SQL的缩写,它指的是非关系型数据库,即有别于Oracle,mysql,sqlserver等常用的关系型数据库.它是以key-value形式存在,即我们熟悉的JSON数据形式. 发展:NoSQL是随着互联网Web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模数据量和高并发的SNS类型的web2.0纯动