创建一个UI Button,当用户点击的时候,主线程会响应及处理点击事件,这里是执行handleButtonAction方法。handleButtonAction方法发起了一个网络请求下载图片。必然的,这是一个耗时的操作。
我们提供的服务有:网站建设、成都做网站、微信公众号开发、网站优化、网站认证、南昌ssl等。为上千企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的南昌网站制作公司
没有所谓好不好,在其他线程更新UI最终还是转变为在UI线程里更新,因为UI线程是主线程,其他线程想直接操作UI是不行的,可以借助Handler and message机制。
在子线程中更新UI:由于安卓更新UI元素必须在主线程中,否则就会出现异常。有时候我们必须在子线程里去执行一些耗时任务,然后根据任务的执行结果来更新相应的UI控件,比如:执行网络请求,需要将传回的数据更新到UI上。
我们常常听到这么一句话:更新UI要在UI线程(或者说主线程)中去更新,不要在子线程中更新UI,而Androidguan 方也建议我们不要在非UI线程直接更新UI。
分类:队列分为串行、并行、主队列、全局队列。任务的执行是在线程上去执行的。分为同步和异步。所以就可以分成:串行队列同步执行、串行队列异步执行、并行队列同步执行、并行队列异步执行。
分析: 这个案例没有使用系统提供的串行或并行队列,而是自己通过 dispatch_queue_create 函数创建了一个 DISPATCH_QUEUE_SERIAL 的串行队列。执行任务1;遇到异步线程,将【任务同步线程、任务4】加入串行队列中。
串行队列实际上是单线程。第二幅图中使用的并行队列,当block加到并行队列中,不会等待正在执行中的处理,而立即分发到可用线程中去执行。所以block1在等待block2在其他线程中执行完毕,然后才执行block3。
造成主队列的相互等待,并非主线程死锁。死锁,崩溃。原因与在主线程同步提交主队列原因相同。由于串行队列的相互等待造成死锁。队列改成并发,可以正常执行。上层业务异步获取结果再调同步也会死锁。
NSLock 是OC层封装底层线程操作来实现的一种锁,继承NSLocking协议。不能迭代加锁,如果发生两次lock,而未unlock过,则会产生死锁问题。
1、通过上图我们可以了解当主线程做了一次删除操作的时候,我们需要将这个操作记录下来,并且当子线程需要操作的时候进行一次主线程的删除操作,这样才能保证数据的正确性。
2、建子线程的时候把主线程中的数组作为lParam传递给子线程。
3、flag用临界区保护,这种方法除了在两个线程同时入临界区时以外,主线程不会被阻塞。当然也可以用Event,子线程SetEvent,主线程定期WaitForSingleObject,把超时设为1。
进入软件的设置里,就可看到多线程设置的相关选项。
当然也可以用Event,子线程SetEvent,主线程定期WaitForSingleObject,把超时设为1。如果子线程需要等待主线程的处理,就再加一个Event,子线程设置flag/触发Event1之后等特第二个Event,主线程处理完毕后触发第二个Event。
使用NSObject 使用NSObject直接就加入了对多线程的支持,允许对象的某个方法在后台运行。