Java 面试多线程刷题

面试== 基础 + 项目 + 算法

基础 = Java基础、多线程、分布式、JVM、集合类、Spring、数据库等, 以问答形式为主, 需要熟记考点。

项目 = 网上跟着做的项目,能说清楚,具有一定的复杂性和工程性。

算法 = 剑指offer + Leetcode 面试原题 + 低配ACM笔试题,笔试题只需要及格即可,难度偏大,刷简历,想办法海投内推。

 

如何理解线程和进程的区别

进程:

  • 进程是操作系统结构的基础
  • 程序在一个数据集合上运行的过程
  • 系统进行资源分配和调度的独立单位

线程:

  • 轻装进程
  • 进程中独立运行的子任务
  • CPU调度和分派的基本单位
  • 基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源

进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

  • 一个程序至少有一个进程,一个进程至少有一个线程
  • 线程的划分尺度小于进程,使得多线程程序的并发性高
  • 进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率
  • 每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制
  • 多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配
  • 线程的创建和切换开销比进程小

 

协程是用户态的线程,没有上下文切换

 

进程的调度方式

基本方式࿱

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值