多线程快速入门

Posted xianshiwang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程快速入门相关的知识,希望对你有一定的参考价值。

应用程序:就是可以执行的软件,如QQ、YY语言。

什么进程:就是正在运行的程序,是所有线程的集合。

什么线程:每一个线程是进程中的一条执行路径,一个独立执行的单元。(是独立运行的一个执行路径或者执行顺序)。 每个线程互补影响,因为自己都是独立运行的。

创建线程有方式:

    继承Thread类,2、实现Runnanle接口、3、使用匿名内部类、4、实现Callable接口 ,5、线程池创建

多线程第一种实现方式: 继承Thread类,覆盖run()方法。

Thread源码解析: public class Thread implements Runnable {} 启动线程用start()方法;

为什么要调用start()方法启动线程 1、start();//启动线程,使虚拟机调用该线程的 run 方法。

 private native void start0();

为什么要覆盖run方法;将自定义的代码存储在run方法中,让线程运行。 Thread类用于描述线程:因为该类定义了一个功能,存储线程要运行的代码,该存储代码就是run方法;

Java中有两种线程,一种是用户线程,另一种是守护线程。

用户线程是指用户自定义创建的线程,主线程停止,用户线程不会停止。 守护线程当进程不存在或主线程停止,守护线程也会被停止。(GC线程) 守护线程和主线程一起销毁

多线程运行状态

技术分享图片

 

 线程从创建、运行到结束总是处于下面五个状态之一:新建状态、就绪状态、运行状态、阻塞状态及死亡状态。

新建状态

   当用new操作符创建一个线程时, 例如new Thread(r),线程还没有开始运行,此时线程处在新建状态。 当一个线程处于新生状态时,程序还没有开始运行线程中的代码

就绪状态

一个新创建的线程并不自动开始运行,要执行线程,必须调用线程的start()方法。当线程对象调用start()方法即启动了线程,start()方法创建线程运行的系统资源,并调度线程运行run()方法。当start()方法返回后,线程就处于就绪状态。

     处于就绪状态的线程并不一定立即运行run()方法,线程还必须同其他线程竞争CPU时间,只有获得CPU时间才可以运行线程。因为在单CPU的计算机系统中,不可能同时运行多个线程,一个时刻仅有一个线程处于运行状态。因此此时可能有多个线程处于就绪状态。对多个处于就绪状态的线程是由Java运行时系统的线程调度程序(thread scheduler)来调度的。

运行状态

当线程获得CPU时间后,它才进入运行状态,真正开始执行run()方法.

阻塞状态

    线程运行过程中,可能由于各种原因进入阻塞状态:
        1>线程通过调用sleep方法进入睡眠状态;
        2>线程调用一个在I/O上被阻塞的操作,即该操作在输入输出操作完成之前不会返回到它的调用者;
        3>线程试图得到一个锁,而该锁正被其他线程持有;
        4>线程在等待某个触发条件;

死亡状态

有两个原因会导致线程死亡:
  1) run方法正常退出而自然死亡,
   2) 一个未捕获的异常终止了run方法而使线程猝死。
  为了确定线程在当前是否存活着(就是要么是可运行的,要么是被阻塞了),需要使用isAlive方法。如果是可运行或被阻塞,这个方法返回true; 如果线程仍旧是new状态且不是可运行的, 或者线程死亡了,则返回false.

join()方法作用

join作用是让其他线程变为等待,    t1.join();// 让其他线程变为等待,直到当前t1线程执行完毕,才释放。

thread.Join把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。

Yield方法

Thread.yield()方法的作用:暂停当前正在执行的线程,并执行其他线程。(可能没有效果)

yield()让当前正在运行的线程回到可运行状态,以允许具有相同优先级的其他线程获得运行的机会。因此,使用yield()的目的是让具有相同优先级的线程之间能够适当的轮换执行。但是,实际中无法保证yield()达到让步的目的,因为,让步的线程可能被线程调度程序再次选中。

多线程分批处理数据

需求:目前XX网站20万个用户,现在需要做活动,给每一个用户发送一条祝福短信。

为了提高数程序的效率,请使用多线程技术分批发送据。

每开一个线程,都会占用CPU资源

服务器(电脑)配置 CPU 核数

技术分享图片

技术分享图片

技术分享图片

技术分享图片

技术分享图片

 










以上是关于多线程快速入门的主要内容,如果未能解决你的问题,请参考以下文章

java多线程快速入门

java多线程快速入门

java多线程快速入门

java多线程快速入门

java多线程快速入门

java多线程快速入门