美文网首页
ios 线程与进程

ios 线程与进程

作者: 寒雨晚风 | 来源:发表于2021-07-31 15:35 被阅读0次

    1.进程 

     具有一定独立功能的程序关于某次数据集合的一次运行活动,他是操作系统分配资源的基本单位。

    进程是指系统正在运行的一个应用程序,就是一段程序的执行过程。

    各进程之间相互独立,每个进程都运行在受保护的内存空间内,拥有独立运行所需的全部资源。

    2. 线程

    进程的最小执行单元。线程是一个进程的实体。

    一个进程要想执行任务,就必须至少又一个线程,当程序启动时,系统默认开启一条线程,也就是主线程。

    3、 进程与线程的关系

    线程是进程的执行单元,进程的所有任务都在线程中执行

    线程是CPU分配和执行任务的最小单元

    一个程序可以有多进程,一个进程可以有多线程 ,但是一个进程至少有一个线程

    同一个进程内的线程共享进程内的资源

    4 多线程原理

    同一时间内单核CPU 只执行一个线程,多线程是CPU 在单位时间内在多个线程之间切换,造成多个线程被同时执行的假象。

    多核CPU 就可以执行多个线程

    多线程的目的是同步执行多个线程,来提高运行效率

    5、多线程的优缺点

    有点:提高执行效率 能够提高CPU的使用率

    缺点:占用一定的系统内存空间  线程越多 CPU 调度线程的开销越大 程序设计复杂(线程之间的通信 数据共享)

    6、多线程并发 与并行区别

    并发:在一条线程上快速切换 

    并行: 利用多核CPU ,多线程同时进行

    7、IOS 中的多线程

    NSThread 需要手动创建 不需要销毁 子线程通信很难

    GCD c语言,充分利用了设备的多核,自动管理线程生命周期。比NSOperation效率更高。

    NSOperation  基于gcd封装,更加面向对象,比gcd多了一些功能。

    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(inti=0; i<10; i++) {

            dispatch_group_enter(downloadGroup);

            NSURLSessionDataTask*task = [sessiondataTaskWithRequest:requestcompletionHandler:^(NSData*_Nullabledata,NSURLResponse*_Nullableresponse,NSError*_Nullableerror) {

                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");

    });

    相关文章

      网友评论

          本文标题:ios 线程与进程

          本文链接:https://www.haomeiwen.com/subject/ptxkvltx.html