多线程概念初识

1. 什么是进程

  • 进程就是操作系统正在执行一个应用程序,也就是程序真正运行的实例,是资源分配的基本单位。像我们用电脑打开LOL 、酷狗音乐等这就是开启了一个进程。

2. 什么是线程

  • 线程是CPU的基本调度单位,每个线程执行的都是进程代码的某个片段,一个进程至少有一个或者多个线程。
  • 举个列子:
    我和一个同事租了一套两居室的房子,这个房子可以理解为进程,房子面积,房间数量就是进程的属性,而我和同事就是该进程中的两个线程,我们可以各自的房间睡觉,做饭,打牌,看电视等操作,这些都比喻线程在进程中去执行不同功能的代码。

3. 进程和线程有哪些不同

  • 先有进程后有线程,线程是在进程下运行的
  • 进程是一个程序运行起来的一个活动,是系统分配资源和调度一个单位,线程是cpu调度的单位
  • 内存共享方式不同,不同进程的内存很难共享,如果要通信要使用ipc 线程是可以共享进程的内存
  • 线程共享进程代码段、共有数据等
  • 线程的堆栈是独有

4. 什么是多线程

  • 一个程序可以运行两个或者以上的线程就是多线程,多线程是指在单个进程中运行多个线程。
  • 拿刚刚和同事租房子的列子来说一下:
    房子是进程,我和同事是两个线程,房子的客厅、厨房都是公共的,我和同事可以随意进出。也就是说线程可以享用进程的公共内存。房子里的卫生间当我同事使用的时候会上锁,这个时候我只有等他完事了我就可以使用,这就是互斥锁。然而我和同事都有自己的卧室,这就比喻每个线程都会有自己的独立资源(线程id,堆栈),当然我也会和同事一起做饭,他备菜我来炒,这样就会很快,我要是一人做就会很慢,这就是多线程的并发和并行工作。

5. 为什么需要多线程

  • 主要目的提高CPU利用率,提高用户体验,避免卡顿,缩短等待时间

6. 什么场景中会使用多线程

  • 定时任务、异步记录日志、异步发送消息(短信,微信推送等)

7. 串行和并行的区别

  • 串行: 大家排队等待,一个一个来
  • 并行: 大家一起来
    -在这里插入图片描述

8. 并发和并行区别

  • 并发:
    多个任务交给单核处理器处理,处理器同时只能处理一个任务,多个任务都是在交替执行的,但是由于处理器运行速度很快,形成的感觉就是在同时处理多个任务。
    在这里插入图片描述

  • 并行: 多个任务交给多核处理器处理,在同一时刻有多个任务同时处理, 并行(两个线程同时执行)一定是并发。
    在这里插入图片描述

  • 上述说的并发只是第一种概念,还有一种叫 ”并发性” ,不同部分可以无序或同时执行,且不影响最终的执行结果,这个就是平时和同行聊的并发。

  • 举个列子: 有一个商品下单的接口,这个商品现在库存为 10,但在同一时刻进来了 10+下单请求,如果要是没有库存验证的逻辑,则最终结果之后10个人买到,其它的则没有,商品库存会变成负数。

9. 什么是高并发

  • 同一个时刻有很多请求发送到服务器,服务器并行处理。
  • 高并发解决方案: 分布式应用,负载均衡+集群

10. 同步和异步的区别

  • 同步: 当所有操作完成,在返回信息给用户,如果响应时间比较慢,会造成卡死现象
  • 异步:客户端发送请求到服务器后,在等待响应的时候可以做其它事情,这样节省时间,提高效率
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值