一、背景

  在没有学习Java多线程以前,总觉得多线程是个很神秘的东西,只有那些大神才能驾驭,新年假期没事就来学习和了解一下Java的多线程,本篇博客我们就来从头说一下多线程到底是怎么回事。

二、概述

  1.进程的概念

    每一个正在运行的程序都是一个进程,它是系统进行资源分配和调用的独立单位。且 每一个进程都有自己的内存空间和系统资源。

  2.线程的概念

    是进程中的单个顺序控制流,是一条执行路径。每个进程都可以拥有一个或者多个线程。各个线程之间都共享所属的那个进程的内存空间和系统资源。

  3.单线程和多线程程序的辨别方式

    如果一个进程只有一条执行路径,则称为单线程程序。 如果一个进程有多条执行路径,则称为多线程程序(经典应用程序:扫雷、迅雷下载)。

    废话不多说,我们直接上图来解释

    

  4.站在线程的角度来解释Java程序运行某各类的main方法

    首先java 命令会启动 java 虚拟机,即启动 JVM,等于启动了一个应用程序,也就是启动了一个进程。该进程会自动启动一个 “主线程” ,然后主线程去调用某个类的 main 方法。所以 main方法运行在主线程中。在此之前的所有程序都是单线程的。

三、多线程程序的实现方式

  1.方式一:继承Thread类,重写run方法。

 package cn.hafiz;

 /*
*多线程demo
*/
public class MyThread extends Thread { @Override
public void run() {
for (int x = 0; x < 200; x++) {
System.out.println(x);
}
} }

  几个需要注意的问题:

    为什么要重写run()方法?

    答:我们只有把想要在线程中运行的代码写在run方法里才能启动线程进行运行。

    启动线程使用的是那个方法?

    答:启动使用的是start方法。

    线程能不能多次启动?

    答:一个线程只能启动一次,否则会报IllegalThreadStateException异常。

    run()和start()方法的区别?

    答:run()方法是普通的方法调用,并不是启用线程,而start方法是首先启动一个新的线程,然后运行run()方法里面的代码。

  2.方式二:实现Runnable接口

 package com.hafiz;

 public class MyRunnable implements Runnable {

     @Override
public void run() {
for (int x = 0; x < 100; x++) {
System.out.println(Thread.currentThread().getName() + ":" + x);
}
} }

  该实现方式优点:

    可以避免由于Java单继承带来的局限性。 适合多个相同程序的代码去处理同一个资源的情况,

    把线程同程序的代码,数据有效分离,较好的体现了面向对象的设计思想。

四、线程基本操作

  1.获取和设置线程名称

    public final String getName();

    public final void setName(String name);

    其实通过构造方法也可以设置线程名称.

    public static Thread currentThread():获取任意方法所在的线程名称.

  2.线程调度

    1).之所以出现线程调度是因为计算机只有一个 CPU,那么 CPU 在某一个时刻只能执行一条指令,线程只有得到 CPU时间片,也就是使用权,才可以执行指令。

    2).线程的两种调度模型(Java使用的是抢占式调度模型).

      分时调度模型:所有线程轮流使用 CPU 的使用权,平均分配每个线程占用 CPU 的时间片。

      抢占式调度模型:优先让优先级高的线程使用 CPU,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的 CPU 时间片相对多一些。

      获取和设置线程优先级的方法:

        public final int getPriority();

        public final void setPriority(int newPriority);

  3.线程控制

    线程休眠:public static void sleep(long millis);

    线程加入:public final void join();

    线程礼让:public static void yield();

    设置是否为守护线程(当所有的线程都为守护线程就不具有抢占CPU执行权的资格):

      public final void setDaemon(boolean on);

    

  上图中的关羽和张飞可以看成守护线程,当刘备主线程消亡以后,两者都不可能再具有获得CPU执行权的资格。

    中断线程:

      public final void stop();(已过时,直接将虚拟机退出)

      public void interrupt();(建议使用,是中断线程并且抛出一个InterruptedException异常,虚拟机不会退出,线程之后的代码会继续执行)

  4.线程生命周期

    1).创建:新建线程对象。

    2).就绪:线程对象已经启动,已经具有获得CPU的资格,但没有获取执行权。

    3).运行:获得了CPU的执行权,执行线程。

    4).阻塞:没有CPU的执行权,只能等待会到就绪状态。

    5).死亡:线程代码运行完毕,线程消亡。

  嫌文字不好理解,直接上图说明:

  

深入聊聊Java多线程的更多相关文章

  1. Java多线程总结之线程安全队列Queue

    在Java多线程应用中,队列的使用率很高,多数生产消费模型的首选数据结构就是队列.Java提供的线程安全的Queue可以分为阻塞队列和非阻塞队列,其中阻塞队列的典型例子是BlockingQueue,非 ...

  2. java多线程之队列

    1.注:先不看阻塞与否,这ReentrantLock的使用方式就能说明这个类是线程安全类. 2.线程安全的类,BlockingQueue,ConcurrentLinkedQueue.这些都是线程安全的 ...

  3. Java 多线程 (并发)总结

    一.概念 1. 维基百科解释 进程是什么? http://zh.wikipedia.org/wiki/%E8%BF%9B%E7%A8%8B 线程是什么? http://zh.wikipedia.org ...

  4. Java多线程:Linux多路复用,Java NIO与Netty简述

    JVM的多路复用器实现原理 Linux 2.5以前:select/poll Linux 2.6以后: epoll Windows: IOCP Free BSD, OS X: kqueue 下面仅讲解L ...

  5. JVM:从实际案例聊聊Java应用的GC优化

    原文转载自美团从实际案例聊聊Java应用的GC优化,感谢原作者的贡献 当Java程序性能达不到既定目标,且其他优化手段都已经穷尽时,通常需要调整垃圾回收器来进一步提高性能,称为GC优化.但GC算法复杂 ...

  6. Java 多线程学习笔记:生产者消费者问题

    前言:最近在学习Java多线程,看到ImportNew网上有网友翻译的一篇文章<阻塞队列实现生产者消费者模式>.在文中,使用的是Java的concurrent包中的阻塞队列来实现.在看完后 ...

  7. Java多线程编程:Callable、Future和FutureTask浅析(多线程编程之四)

    java多线程-概念&创建启动&中断&守护线程&优先级&线程状态(多线程编程之一)java多线程同步以及线程间通信详解&消费者生产者模式&死锁& ...

  8. 【java】Java多线程总结之线程安全队列Queue【转载】

    原文地址:https://www.cnblogs.com/java-jun-world2099/articles/10165949.html ============================= ...

  9. 【对线面试官】Java多线程基础

    // 请求直接交给线程池来处理 public void push(PushParam pushParam) { try { pushServiceThreadExecutor.submit(() -& ...

随机推荐

  1. Word图片上传控件-eWebEditor9x整合教程-Xproer.WordPaster

    示例下载(JSP):eWebEditor9x, 示例下载(.NET):eWebEditor9x,   1.1. 集成到eWebEditor9x 主要步骤如下: 1.增加WordPaster文件夹   ...

  2. CCommandLineInfo类

    ## CCommandLineInfo cmdInfo;//定义命令行 ParseCommandLine(cmdInfo);//解析命令行 // 调度在命令行中指定的命令.如果 // 用 /RegSe ...

  3. 1098 Insertion or Heap Sort

    1098 Insertion or Heap Sort (25 分) According to Wikipedia: Insertion sort iterates, consuming one in ...

  4. python coroutine的学习跟总结[转]

    简介 因为最近一段时间需要研究一些openstack相关的东西,在阅读一些相关代码的时候碰到很多python特定的一些特性,比如generator, coroutine以及一些相关的类库,比如even ...

  5. 利用irc服务器做物联网数据转发 c# winform程序

    利用irc协议的优点: 免费,不用购买服务器就可以实现稳定公网转发数据 开源,irc的客户端和开源库众多,省去了自己造轮子的时间 历史悠久,互联网诞生伊始就有irc 缺点:安全性比较差 简单协议接收可 ...

  6. java基础-day29

    第06天 MySQL数据库 今日内容介绍 u MySQL单表查询 u SQL约束 u 多表操作 第1章   MySQL单表查询 1.1  SQL单表查询--排序 1.1.1 排序格式 通过order ...

  7. 基类的析构函数写成virtual虚析构函数

    虚函数作用:动态绑定,实现多态效果. 场景问题: 派生类中有资源需要回收,而在编程中采用多态,由基类的指针指向派生类,则在释放的时候,如果基类的析构函数不是virtual,则派生类的析构函数得不到释放 ...

  8. HDU 2476 区间DP-刷字符问题-思维考察

    区间DP-刷字符问题-思维考察 翻译了一下这个题,一看还是有点难以入手,标明了是区间DP问题,但是如何DP呢 来捋一捋思路吧 dp[i][j]肯定是从i刷到j所要的次数但是它的i和j是s1串还是s2串 ...

  9. 火狐浏览器(Firefox)打开EBS form的设置方法

    http://yedward.net/?id=247 客户在使用EBS的时候,很多都是使用IE浏览器打开,但是EBS并不仅仅只是支持IE,对于谷歌浏览器(Chrome).火狐浏览器(Firefox)也 ...

  10. Android开发教程 - 使用Data Binding(六)RecyclerView Adapter中的使用

    本系列目录 使用Data Binding(一)介绍 使用Data Binding(二)集成与配置 使用Data Binding(三)在Activity中的使用 使用Data Binding(四)在Fr ...