线程:

  • 定义:线程是程序内的一个单一的顺序控制流程,也被称为“轻型进程(lightweight process)” 或“执行上下文(execution context )”
  • 线程用于分隔任务
  • 线程类似于传统的顺序程序,都有一个执行的起点,经过一系列指令后到达终点。线程在执行过程中的任何时刻只能有一个执行点
  • main()是一个特殊的线程

实现方法:

1.继承Thread

2.实现runnable接口

启动方式:

1.start() 交叉执行线程,一个等待即执行下一个,各个线程的xc1.start();

xc2.start();

xc3.start();

执行并不是顺序的,谁先获取cpu执行谁

2.run()  顺序执行线程,一个执行完才能执行下一个

线程共享资源:

设置为static静态

线程状态:

创建

就绪

执行

阻塞

死亡

线程通信:

线程常用方法:

Thread.currentThread().getName();获取正在执行的线程的名字

//主动放弃cpu执行权的三种方法

Thread.yield();thread的静态方法,当前执行线程放弃cpu执行权进入就绪态;

Thread.sleep(t); thread的静态方法,睡眠一段时间,进入阻塞态,时间到自动进入就绪态;

wait([t]);Object方法等待【一定时间】进入阻塞态,等待唤醒

notify()唤醒持有指定锁阻塞状态的线程任意一个,进入就绪

notifyAll()唤醒持有指定锁阻塞状态的所有进程,进入就绪

stop()终止线程

thread.setPriority(1--10);//线程优先级,1—10越来越大,只是提高获取cpu的概率,并不是优先级高的绝对先获取cpu

继承Thread过程

1.创建一个类继承Thread

2.重写Thread中的run方法 (创建线程是为了执行任务     任务代码必须有存储位置,run方法就是任务代码的存储位置。)thread里的run()可以调用其他方法

3.创建子类对象,其实就是在创建线程

4.启动线程start()或者run()

这种方式的特点(缺陷):线程任务和线程是绑定在一起的。

实例:

class Ticket extends Thread{

private static int num = 50; //定义成static,四个线程共享50张票。

public void run() {

while(num>0)

System.out.println(Thread.currentThread().getName()+"...sale..."+num--);

}

}

class Maipiao{

public static void main(String[] args) {

Ticket win1 = new Ticket();

Ticket win2 = new Ticket();

Ticket win3 = new Ticket();

Ticket win4 = new Ticket();

win1.start();

win2.start();

win3.start();

win4.start();

}

}

实现runnable接口:过程

  1. 创建类并实现Runnable接口
  2. 重写Runnable接口中的run方法
  3. 创建实现了Runnable接口的子类的对象
  4. 创建Thread类的对象,也就是在创建线程
  5. 把实现了Runnable接口的子类对象作为参数传递给Thread类的构造方法

实例:

package thread;

/**

* 应用模块名称<p>

* 代码描述<p>

* Copyright: Copyright (C) 2019 XXX, Inc. All rights reserved. <p>

* Company: 河南863<p>

*

* @author 闫聪

* @since 2019/7/19 10:26

*/

public class Demo2 {

public static void main(String[] args) {

MyThreadTwo myThreadTwo = new MyThreadTwo();

Thread thread=new Thread(myThreadTwo,"窗口1");

Thread thread2=new Thread(myThreadTwo,"窗口2");

Thread thread3=new Thread(myThreadTwo,"窗口3");

Thread thread4=new Thread(myThreadTwo,"窗口4");

thread.start();

thread2.start();

thread3.start();

thread4.start();

//myThreadTwo.start();

}

}

class MyThreadTwo implements Runnable{

//方式二:成员变量属于共享资源,多个线程共享一个对象

private int num =100;

@Override

public void run() {

System.out .println ("ss"+num);

synchronized (this){

while(num>0){

num=num-1;

if(num==0){

this.notifyAll();

break;

}

System.out.println(Thread.currentThread().getName()+"...sale..."+num);

if(num<100&&num%2==0){

this.notify();

try {

this.wait();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

}

}

}

Java学习笔记——线程的更多相关文章

  1. Java学习笔记 线程池使用及详解

    有点笨,参考了好几篇大佬们写的文章才整理出来的笔记.... 字面意思上解释,线程池就是装有线程的池,我们可以把要执行的多线程交给线程池来处理,和连接池的概念一样,通过维护一定数量的线程池来达到多个线程 ...

  2. Java 学习笔记 线程控制

    题目一 本质上来说,线程是不可控制的,线程的执行是由CPU资源分配决定的,我们无法干预系统CPU的资源分配,但我们可以增加条件来让线程按照我们的预想顺序来执行. 比如.如果当前的执行的线程不满足我们所 ...

  3. java学习笔记 - 线程池(一)

    线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销 优点:(面试题)可重复使用已有线程,避免对象创建.消亡和过度切换的性能开 ...

  4. java学习笔记 线程的实现与同步

    2019.4.2 线程实现的两种方式 继承线程,复写其中的run方法 实现runnable接口,复写run方法 使用: MyThread target = new MyThread(); new Th ...

  5. Java学习笔记--线程day01

    线程的概念:一个线程是进程的顺序执行流: 同类的多个线程共享一块内存空间和一组系统资源,线程本身有一个供程序执行时的堆栈.线程在切换时负荷小,因此,线程也被称为轻负荷进程.一个进程中可以有多个线程. ...

  6. Java学习笔记-多线程-创建线程的方式

    创建线程 创建线程的方式: 继承java.lang.Thread 实现java.lang.Runnable接口 所有的线程对象都是Thead及其子类的实例 每个线程完成一定的任务,其实就是一段顺序执行 ...

  7. java学习笔记15--多线程编程基础2

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡 ...

  8. java学习笔记14--多线程编程基础1

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...

  9. 0037 Java学习笔记-多线程-同步代码块、同步方法、同步锁

    什么是同步 在上一篇0036 Java学习笔记-多线程-创建线程的三种方式示例代码中,实现Runnable创建多条线程,输出中的结果中会有错误,比如一张票卖了两次,有的票没卖的情况,因为线程对象被多条 ...

随机推荐

  1. CentOS7 配置阿里云yum源,vim编辑器,tab自动补全

    1.进入yum的文件夹 命令:cd   /etc/yum.repos.d/ 2.下载wget 命令:yum -y install wget 3.删除yum文件夹所有yum源 命令:rm -rf    ...

  2. .Net 下基于Redlock redis 分布式锁实现

    Redlock-cs (C#/.NET implementation). RedLock.net (C#/.NET implementation). Includes async and lock e ...

  3. 如果设置Redis客户端的超时时长?

    客户端的超时时长分连接超时和读写超时,如果是基于hiredis的实现,则读写超时是合在一起的,同一参数控制. 在hiredis中,读写超时调用函数redisSetTimeout设置,可以看到没有区分读 ...

  4. 【JZOJ6232】【20190625】喜欢最最痛

    题目 \(n\)个节点的树,边权为正整数. 从1 号点开始走一个路径并最终回到 1 号点,且这条路径经过了所有的边. 一条路径的代价就是它经过的边的边权之和. 可以加若干条额外边,第 i 条加的额外边 ...

  5. pandas批量读取带有日期的文件夹简单操作

    工作中碰到了这样一个数据处理的问题,想让你把某个文件夹下的子文件夹中的excel表级联成为1张表,用excel来做会很浪费时间并且很劳累,这时候我们就可以用pandas来加大工作效率,只需要半个小时就 ...

  6. python 判断操作系统以及操作系统版本号

    >>> import platform >>> platform.platform() 'Darwin-17.7.0-x86_64-i386-64bit' > ...

  7. JavaScript 整数转大写中文

    function toChinese(money){ var chNum=['零','壹','贰','叁','肆','伍','陆','柒','捌','玖']; var maxnum=999999999 ...

  8. R 语言输入输出 读取命令函参数

    输入数据 使用键盘输入数据 只能处理小样本,很少使用 在创建 data.txt 字符串之后,用函数 read.table() 创建数据框 data.1.这种方法可以让我们把数据嵌入到R代码中,此处切记 ...

  9. 调用Fluent进行多工况计算总结

    算例来源:https://confluence.cornell.edu/display/SIMULATION/FLUENT+-+Turbulent+Pipe+Flow 有时候我们对同一模型进行多工况计 ...

  10. jemalloc内存分配原理【转】

    原文:http://www.cnblogs.com/gaoxing/p/4253833.html 内存分配是面向虚拟内存的而言的,以页为单位进行管理的,页的大小一般为4kb,当在堆里创建一个对象时(小 ...