文章讲解要点

1.线程创建几种方式
2.线程常见设置方法,包括优先级、优先级休眠、停止等
3.多线程间的数据交互与锁机制
4.项目源码下载

 
线程介绍.png

一、线程创建方式

常见的线程创建方法以下三种:

1.使用继承Thread类的方式

public class CreateThread1{

    static class TestThread extends Thread {

        public void run() {

            for (int i = 0; i < 50; i++) {

                System.out.println(i + " 多线程1...");

            }}
} static class TestThread2 extends Thread { public void run() { for (int i = 0; i < 500; i++) { System.out.println(i + " 多线程2..."); }
}
} public static void main(String[] args) { TestThread testThread = new TestThread(); TestThread2 testThread2 = new TestThread2(); testThread.start();//启动线程 testThread2.start();//启动线程 for (int i = 0; i < 10000; i++)
{ System.out.println(i + " 主线程..."); }
} }

运行结果如下:

 

温馨提示:该方法缺点是:线程类已经继承了Thread类,所以不能再继承其他父类

2.采用实现Runnable方式

public class CreateThread2 {

    static class TestRunnable implements Runnable {
public void run() {
for (int i = 0; i < 500; i++) {
System.out.println(i + " 多线程1...");
}
}
} static class TestRunnable2 implements Runnable {
public void run() {
for (int i = 0; i < 500; i++) {
System.out.println(i + " 多线程2...");
}
}
} public static void main(String[] args) { TestRunnable testRunnable = new TestRunnable(); TestRunnable2 testRunnable2 = new TestRunnable2(); new Thread(testRunnable).start();//启动线程 new Thread(testRunnable2).start();//启动线程 for (int i = 0; i < 10000; i++) {
System.out.println(i + " 主线程...");
}
} }

运行结果如下:

 

3.匿名内部类

该方法比较少用,此处不进行详细介绍。

二、线程常见设置方法

通用线程类

public class CurrencyThread {

    public static class TestThread extends Thread {

        public void run() {

            for (int i = 0; i < 50; i++) {

                System.out.println(i + " 多线程1...");

            }
}
} public static class TestThread2 extends Thread { public void run() { for (int i = 0; i < 500; i++) { System.out.println(i + " 多线程2..."); }
}
}
}

线程优先级设置

1.记住当线程的优先级没有指定时,所有线程都携带普通优先级
2.优先级可以用从1到10的范围指定。10表示最高优先级,1表示最低优先级,5是普通优先级
3.记住优先级最高的线程在执行时被给予优先。但是不能保证线程在启动时就进入运行状态
4.由调度程序决定哪一个线程被执行
5.t.setPriority()用来设定线程的优先级
6.记住在线程开始方法被调用之前,线程的优先级应该被设定

public class ThreadPriority {

    public static final int MIN_PRIORITY = 1;//最低优先级

    public static final int NORM_PRIORITY = 5;//普通优先级

    public static final int MAX_PRIORITY = 10;//最大优先级

    public static void main(String[] args) {

        CurrencyThread.TestThread testThread = new CurrencyThread.TestThread();

        CurrencyThread.TestThread2 testThread2 = new CurrencyThread.TestThread2();

        testThread.setPriority(NORM_PRIORITY);

        testThread.setPriority(MAX_PRIORITY);

        testThread.start();//启动线程

        testThread2.start();//启动线程

        for (int i = 0; i < 10000; i++)
{ System.out.println(i + " 主线程..."); } } }

运行结果如下:

 

线程休眠

线程休眠方法为:sleep();

public class CommonSettings {

    public static void main(String[] args) throws InterruptedException {

        TestThread testThread = new TestThread();

        testThread.start();

    }
} class TestThread extends Thread { public void run() { for (int i = 0; i < 50; i++) { System.out.println("当前值为:" + i + "当前时间为:" + new Date()); try { sleep(2000);//线程休眠2s } catch (InterruptedException e) { e.printStackTrace(); } }
}
}

运行结果如下:

 

线程暂停与恢复

  暂停线程使用Thread中的suspend()方法;恢复暂停的线程使用resume()方法;但两个方法已经不推荐使用了,详情查看源代码

线程中断

  实现方法为:interrupt();并不能使线程结束运行,只是告知线程有一个中断请求,线程不断地检测中断状态,以便进行相应地操作.比如停止线程操作。停止线程操作:不断地检测中断状态,如果产生中断,使用return或者break结束线程,详情查看源代码

三、多线程间的数据交互与锁机制

为什么要使用锁机制
我们所熟知的Java锁机制无非就是Sychornized 锁 和 Lock锁
Synchronized是基于JVM来保证数据同步的,而Lock则是在硬件层面,依赖特殊的CPU指令实现数据同步的

  • Synchronized,它就是一个:非公平,悲观,独享,互斥,可重入的重量级锁
  • ReentrantLock,它是一个:默认非公平但可实现公平的,悲观,独享,互斥,可重入,重量级锁。
  • ReentrantReadWriteLocK,它是一个,默认非公平但可实现公平的,悲观,写独享,读共享,读写,可重入,重量级锁。

Synchronized的作用:

在JDK1.5之前都是使用synchronized关键字保证同步的,它可以把任意一个非NULL的对象当作锁。

  1. 作用于方法时,锁住的是对象的实例(this);
  2. 当作用于静态方法时,锁住的是Class实例,又因为Class的相关数据存储在永久带PermGen(jdk1.8则是metaspace),永久带是全局共享的,因此静态方法锁相当于类的一个全局锁,会锁所有调用该方法的线程;
  3. synchronized作用于一个对象实例时,锁住的是所有以该对象为锁的代码块。

  了解了锁机制之后,我们进一步了解线程间数据共享与不共享
  不共享数据的多线程:不共享数据就是每个都是独立的线程

public class ThreadLock {

    /**
* 测试不共享数据的多线程
*/
static class NotShareThread extends Thread { private int count=5; public NotShareThread(String name){ super(); this.setName(name); } @Override public void run(){ super.run(); while(count>0){ count--; System.out.println(Thread.currentThread().getName()+"此时的count="+count); } } }
public static void main(String[] args) { //测试不共享数据的多线程
NotShareThread nsd1= new NotShareThread("01"); NotShareThread nsd2= new NotShareThread("02"); NotShareThread nsd3= new NotShareThread("03"); nsd1.start(); nsd2.start(); nsd3.start(); }
}

运行结果如下:

 

共享数据的多线程:共享数据的情况就是多个线程可以访问同一个对象

public class ThreadLock {
/**
* 数据共享的线程测试
*/
static class ShareThread extends Thread { private int count=5; @Override public void run(){ super.run(); System.out.println(Thread.currentThread().getName() + "此时访问了"); synchronized (this)
{
count--; System.out.println(Thread.currentThread().getName()+"此时的count="+count); try { sleep(2000); } catch (InterruptedException e) { e.printStackTrace();
}
} } } public static void main(String[] args) { ShareThread st = new ShareThread(); //用的是同一个对象,就实现了数据共享了
Thread t1=new Thread(st,"1"); Thread t2=new Thread(st,"2"); Thread t3=new Thread(st,"3"); Thread t4=new Thread(st,"4"); Thread t5=new Thread(st,"5"); t1.start(); t2.start(); t3.start(); t4.start(); t5.start(); }
}

运行结果如下:

 

实际应用场景介绍
   大家可以看到我们在代码块中加入了synchronized锁机制,以保证数据的同步,因为在某些实际项目操作中,数据的操作必须保持唯一性,比如银行存款取款操作。

  1. 不采用锁机制:
    现ATM机的管理中心余额为1000元,有两个人同时在操作ATM机器,一人存500,一人取50,第一个人操作完成时,管理中心显示余额为1500,第二个人操作完成时,管理中心显示余额为950,但是实际真的是这样的吗?我们再来看看锁机制的处理方式是怎样的!

  2. 采用锁机制:
    现ATM机的管理中心余额为1000元,有两个人同时在操作ATM机器,一人存500,一人取50,在第一个人未完成操作时,第二个人是处于交易处理中的,当一个人存钱完成时,第二个人获取到管理中心余额为1500元后再进行取款,之后管理中心显示余额为1450元。

四、项目源码下载

链接:https://pan.baidu.com/s/10Hw9lQ5RiAGLVlFaEz4p0A
提取码:x5br

java线程介绍的更多相关文章

  1. Java线程池的原理及几类线程池的介绍

    刚刚研究了一下线程池,如果有不足之处,请大家不吝赐教,大家共同学习.共同交流. 在什么情况下使用线程池? 单个任务处理的时间比较短 将需处理的任务的数量大 使用线程池的好处: 减少在创建和销毁线程上所 ...

  2. java jstack dump 线程 介绍 解释

    最近抽时间把JVM运行过程中产生的一些线程进行了整理,主要是围绕着我们系统jstack生成的文件为参照依据.  前段时间因为系统代码问题,造成性能到了天花板,于是就dump了一份stack出来进行分析 ...

  3. java线程池技术(二): 核心ThreadPoolExecutor介绍

    版权声明:本文出自汪磊的博客,转载请务必注明出处. Java线程池技术属于比较"古老"而又比较基础的技术了,本篇博客主要作用是个人技术梳理,没什么新玩意. 一.Java线程池技术的 ...

  4. Java线程状态介绍

    原创:转载需注明原创地址 https://www.cnblogs.com/fanerwei222/p/11867086.html Java 线程状态介绍: Java官方文档中对Java线程的几种状态做 ...

  5. Java 线程池(一):开篇及Executor整体框架介绍

    一.开篇 线程池.数据库连接池,在平时的学习中总能接触到这两个词,但它们到底是什么?和线程,数据库连接有什么关系?为什么需要“池”?“池”的概念及作用是什么?要弄清楚这些问题,就要深入到“池”的实现中 ...

  6. 【转载】 Java线程面试题 Top 50

    Java线程面试题 Top 50 不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题.Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员 的欢迎.大多数待遇丰厚的J ...

  7. 第23章 java线程通信——生产者/消费者模型案例

    第23章 java线程通信--生产者/消费者模型案例 1.案例: package com.rocco; /** * 生产者消费者问题,涉及到几个类 * 第一,这个问题本身就是一个类,即主类 * 第二, ...

  8. [转]Java线程安全总结

    最近想将java基础的一些东西都整理整理,写下来,这是对知识的总结,也是一种乐趣.已经拟好了提纲,大概分为这几个主题: java线程安全,java垃圾收集,java并发包详细介绍,java profi ...

  9. JVM 内部运行线程介绍

    转(http://club.alibabatech.org/article_detail.htm?articleId=4) JVM 内部运行线程介绍 作者:蒋家佳/觉梦(支付宝开发工程师) 浏览量: ...

随机推荐

  1. [Reversing.kr] Easy ELF Writeup

    IDA打开,看到main()函数,当sub_8048451() 返回1 是flag正确. 跟踪函数. 脚本: #!usr/bin/env python #!coding=utf-8 __author_ ...

  2. vue-cli中webpack配置详解

    vue-cli是构建vue单页应用的脚手架,命令行输入vue init <template-name> <project-name>从而自动生成的项目模板,比较常用的模板有we ...

  3. Android Studio代码行数统计插件Statistics

    Android Studio 是没有提提供统计代码全部行数的功能的,但是对于开发者来说,这个功能确实必备的,Statistic统计代码行数非常方便,也很详细. 1,首先肯定是将插件下载下来,下载地址: ...

  4. ZooKeeper 01 - 什么是ZooKeeper + 部署ZooKeeper集群

    目录 1 什么是ZooKeeper 2 ZooKeeper的功能 2.1 配置管理 2.2 命名服务 2.3 分布式锁 2.4 集群管理 3 部署ZooKeeper集群 3.1 下载并解压安装包 3. ...

  5. 知其所以然~tcp和udp的区别

    TCP UDP TCP与UDP基本区别 基于连接与无连接 TCP要求系统资源较多,UDP较少: UDP程序结构较简单 流模式(TCP)与数据报模式(UDP); TCP保证数据正确性,UDP可能丢包 T ...

  6. Asp.Net Core与携程阿波罗(Apollo)的第一次亲密接触

    一.瞎扯点什么 1.1 阿波罗 ​ 阿波罗是希腊神话中的光明之神.文艺之神,同时也是罗马神话中的太阳神:他是光明之神,从不说谎,光明磊落,在其身上找不到黑暗,也被称作真理之神.他非常聪明,通晓世事,是 ...

  7. centos中安装虚拟机

    我这里选用的虚拟机软件为virtualbox 下载wget http://download.virtualbox.org/virtualbox/5.2.2/VirtualBox-5.2-5.2.2_1 ...

  8. 谈谈iOS获取调用链

    本文由云+社区发表 iOS开发过程中难免会遇到卡顿等性能问题或者死锁之类的问题,此时如果有调用堆栈将对解决问题很有帮助.那么在应用中如何来实时获取函数的调用堆栈呢?本文参考了网上的一些博文,讲述了使用 ...

  9. Spring基础系列--AOP织入逻辑跟踪

    原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9619910.html 其实在之前的源码解读里面,关于织入的部分并没有说清楚,那些前置.后 ...

  10. Smobiler 4.4 更新预告 Part 2(Smobiler能让你在Visual Studio上开发APP)

    Hello Everybody,在Smobiler 4.4中,也为大家带来了新增功能和插件(重点,敲黑板). 新增功能: 1, 企业认证用户可设置路由(即客户端可根据不同的IP地址访问不同的服务器组) ...