多线程_01_基础

如何理解线程,那就通过比较进程和线程让我们更好的理解。

 

比较进程和线程:

进程:正在系统上运行的程序

线程:每个进程包括1-多个线程,一组指令的集合,也可以理解为代码运行的上下文,负责在单个程序里执行多个任务。

 


理解

内存

举例

进程

系统上运行的程序

独占一块内存空间

运行的某个exe程序

线程

进程中的一个执行流程

多个线程共享进程的内存

一个exe进程可以运行很多线程

 

多线程:指从软件或者硬件上实现多个线程并发执行的技术。简单来说就是实现多任务的一种方式。

 

为了让程序运行的更快,往往并发执行多个线程,是不是启动更多的线程就能让程序最大限度的并发执行?

当然不是的,并发执行多个线程往往面临上下文切换,死锁,以及受限于硬件和软件的资源限制等问题,所以要结合你的并发量、软硬件资源等情况使用多线程。

 

既然上下文切换有消耗,如果减少上下文切换呢?

并发执行只是人的感觉,实际上线程的执行是CPU通过不同的切换线程执行的。

CPU为每个线程分配时间片,如果当前任务执行一个时间片后会切换到下一个任务,但是在切换之前会保存当前这个任务的状态,等下次再切换回该任务时,可以继续加载该状态。这就是一次上下文切换。

减少上下文切换的方法:

1、无锁并发编程,能避免不使用锁,用其他的方式处理。

2、CAS算法,更新数据时使用CAS算法更新,避免了使用锁,满足了无锁并发编程

3、使用最少线程,创建线程要考虑该线程是否是必须线程,创建不需要的线程不仅不会提高性能,反而由于上下文切换造成不必要的消耗

4、协成:单线程实现多任务调度,并维持多个任务间的切换。(参考Java并发编程的艺术)

 

分类:用户线程、守护线程

用户线程执行完毕,JVM自动关闭。守护线程不独立于JVM,一般由操作系统或者用户自己创建。

守护线程需要调用线程对象的方法setDaemon(true),该方法必须在启动线程前调度,当正在运行的程序都是守护线程时,java虚拟机退出.


线程的生命周期:

线程也是有生命周期的,是一个动态执行的过程,从产生到死亡的过程。由以下5种状态:



以上是对线程做的一些基本概念的总结,多线程需要了解的还很多,用好多线程,不仅提高系统的性能,而且可以更加合理的利用好资源。




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值