8-多线程知识&进程

文章详细介绍了进程和线程的区别,强调进程有独立的内存空间,线程是进程中的执行单元,更容易共享数据。接着讨论了死锁现象,它是多个线程竞争资源导致的僵局,并提出了避免死锁的四种方法。最后,解释了线程池的概念,作为提高资源利用率和避免频繁线程创建的技术。
摘要由CSDN通过智能技术生成
  • 什么是进程?
    在内存中运行的应用程序,有自己独立的内存空间,一个进程可以拥有多个线程。

·
·
·

  • 什么是线程?
    进程中的一个执行单元,负责进程中程序的运行。

·
·
·

  • 进程和线程的区别?
    1.一个进程可以有多个线程。
    2.进程之间的数据很难共享,因为每个进程是独立运行在自己的内存空间。
    3.线程直接的数据共享就比较容易。
    4.进程要比线程消耗的资源更多。

·
·
·

  • 什么是死锁?
    多个线程对同一资源进行竞争锁造成的一种阻塞现象,如果没有外力干涉程序就无法运行下去,这就是死锁。

·
·
·

  • 怎么避免死锁?
    首先死锁的形成需要四个条件,分别是
    互斥条件:一个资源只允许一个线程访问,已经被访问的资源再被其他线程访问就会等待。
    占有且等待:就是一个线程已经占有了一个或多个资源,但是它还需要占有被其他线程占有资源。
    不可抢占条件:一个资源已经被其他线程占有,其他的线程不能因为需要这个资源就去尝试占有它。
    循环等待:存在一个进程链,每一个进程都要占有下一个进程的资源才能正常推进。

·
·
·

  • 只要打破这四个条件中的一个就可以避免死锁。

·
·
·

  • 打破互斥条件:基本不可能打破,因为线程本身就是互斥的。
  • 打破占有且等待条件:一个进程正常推进过程中如果拥有全部的资源才允许推进,否则就进入等待,等满足全部资源条件再执行。
  • 打破不可抢占条件:当进程去尝试占有其他进程的资源得不到满足时,退出所占有的资源进行等待。
  • 循环等待:使资源访问设定一个有序策略。

·
·
·

  • 线程池的理解:
    线程池是一种池化技术,也是一种多线程处理形式,任务的执行交由线程池来管理,
    在执行结束之后可以将线程重新放回线程池,避免了线程的频繁创建,提高资源的使用率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值