ios 线程与进程
发布网友
发布时间:2022-04-22 10:02
我来回答
共1个回答
热心网友
时间:2023-10-09 21:19
1.进程
具有一定独立功能的程序关于某次数据集合的一次运行活动,他是操作系统分配资源的基本单位。
进程是指系统正在运行的一个应用程序,就是一段程序的执行过程。
各进程之间相互独立,每个进程都运行在受保护的内存空间内,拥有独立运行所需的全部资源。
2. 线程
进程的最小执行单元。线程是一个进程的实体。
一个进程要想执行任务,就必须至少又一个线程,当程序启动时,系统默认开启一条线程,也就是主线程。
3、 进程与线程的关系
线程是进程的执行单元,进程的所有任务都在线程中执行
线程是CPU分配和执行任务的最小单元
一个程序可以有多进程,一个进程可以有多线程 ,但是一个进程至少有一个线程
同一个进程内的线程共享进程内的资源
4 多线程原理
同一时间内单核CPU 只执行一个线程,多线程是CPU 在单位时间内在多个线程之间切换,造成多个线程被同时执行的假象。
多核CPU 就可以执行多个线程
多线程的目的是同步执行多个线程,来提高运行效率
5、多线程的优缺点
有点:提高执行效率 能够提高CPU的使用率
缺点:占用一定的系统内存空间 线程越多 CPU 调度线程的开销越大 程序设计复杂(线程之间的通信 数据共享)
6、多线程并发 与并行区别
并发:在一条线程上快速切换
并行: 利用多核CPU ,多线程同时进行
7、IOS 中的多线程
NSThread 需要手动创建 不需要销毁 子线程通信很难
GCD c语言,充分利用了设备的多核,自动管理线程生命周期。比NSOperation效率更高。
NSOperation 基于*封装,更加面向对象,比*多了一些功能。
8、多个网络请求如何执行下一步
使用GCD的dispatch_group_t
创建一个dispatch_group_t
每次网络请求前先dispatch_group_enter,请求回调后再dispatch_group_leave,enter和leave必须配合使用,有几次enter就要有几次leave,否则group会一直存在。
当所有enter的block都leave后,会执行dispatch_group_notify的block。
NSString *str = @"http://www.jianshu.com/p/6930f335adba";
NSURL*url = [NSURLURLWithString:str];
NSURLRequest*request = [NSURLRequestrequestWithURL:url];
NSURLSession *session = [NSURLSession sharedSession];
dispatch_group_tdownloadGroup =dispatch_group_create();
for ( int i=0; i<10; i++) {
dispatch_group_enter(downloadGroup);
NSURLSessionDataTask*task = [sessiondataTaskWithRequest:requestcompletionHandler:^(NSData* _Nullable data,NSURLResponse* _Nullable response,NSError* _Nullable error) {
NSLog(@"%d---%d",i,i);
dispatch_group_leave(downloadGroup);
}];
[taskresume];
}
dispatch_group_notify(downloadGroup, dispatch_get_main_queue(), ^{
NSLog(@"end");
});
7.多个网络请求顺序执行后如何执行下一步?
使用信号量semaphore
每一次遍历,都让其dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER),这个时候线程会等待,阻塞当前线程,直到dispatch_semaphore_signal(sem)调用之后
NSString*str=@"http://www.jianshu.com/p/6930f335adba";
NSURL*url=[NSURL URLWithString:str];
NSURLRequest*request=[NSURLRequest requestWithURL:url];
NSURLSession*session=[NSURLSession sharedSession];
dispatch_semaphore_t sem=dispatch_semaphore_create(0);
for(inti=0;i<10;i++){
NSURLSessionDataTask*task=[session dataTaskWithRequest:request completionHandler:^(NSData*_Nullable data,NSURLResponse*_Nullable response,NSError*_Nullable error){
NSLog(@"%d---%d",i,i);
dispatch_semaphore_signal(sem);
}];
[task resume];
dispatch_semaphore_wait(sem,DISPATCH_TIME_FOREVER);
}
dispatch_async(dispatch_get_main_queue(),^{
NSLog(@"end");
});