Java学习笔记——线程
线程:
- 定义:线程是程序内的一个单一的顺序控制流程,也被称为“轻型进程(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接口:过程
- 创建类并实现Runnable接口
- 重写Runnable接口中的run方法
- 创建实现了Runnable接口的子类的对象
- 创建Thread类的对象,也就是在创建线程
- 把实现了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学习笔记——线程的更多相关文章
- Java学习笔记 线程池使用及详解
有点笨,参考了好几篇大佬们写的文章才整理出来的笔记.... 字面意思上解释,线程池就是装有线程的池,我们可以把要执行的多线程交给线程池来处理,和连接池的概念一样,通过维护一定数量的线程池来达到多个线程 ...
- Java 学习笔记 线程控制
题目一 本质上来说,线程是不可控制的,线程的执行是由CPU资源分配决定的,我们无法干预系统CPU的资源分配,但我们可以增加条件来让线程按照我们的预想顺序来执行. 比如.如果当前的执行的线程不满足我们所 ...
- java学习笔记 - 线程池(一)
线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销 优点:(面试题)可重复使用已有线程,避免对象创建.消亡和过度切换的性能开 ...
- java学习笔记 线程的实现与同步
2019.4.2 线程实现的两种方式 继承线程,复写其中的run方法 实现runnable接口,复写run方法 使用: MyThread target = new MyThread(); new Th ...
- Java学习笔记--线程day01
线程的概念:一个线程是进程的顺序执行流: 同类的多个线程共享一块内存空间和一组系统资源,线程本身有一个供程序执行时的堆栈.线程在切换时负荷小,因此,线程也被称为轻负荷进程.一个进程中可以有多个线程. ...
- Java学习笔记-多线程-创建线程的方式
创建线程 创建线程的方式: 继承java.lang.Thread 实现java.lang.Runnable接口 所有的线程对象都是Thead及其子类的实例 每个线程完成一定的任务,其实就是一段顺序执行 ...
- java学习笔记15--多线程编程基础2
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡 ...
- java学习笔记14--多线程编程基础1
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...
- 0037 Java学习笔记-多线程-同步代码块、同步方法、同步锁
什么是同步 在上一篇0036 Java学习笔记-多线程-创建线程的三种方式示例代码中,实现Runnable创建多条线程,输出中的结果中会有错误,比如一张票卖了两次,有的票没卖的情况,因为线程对象被多条 ...
随机推荐
- CentOS7 配置阿里云yum源,vim编辑器,tab自动补全
1.进入yum的文件夹 命令:cd /etc/yum.repos.d/ 2.下载wget 命令:yum -y install wget 3.删除yum文件夹所有yum源 命令:rm -rf ...
- .Net 下基于Redlock redis 分布式锁实现
Redlock-cs (C#/.NET implementation). RedLock.net (C#/.NET implementation). Includes async and lock e ...
- 如果设置Redis客户端的超时时长?
客户端的超时时长分连接超时和读写超时,如果是基于hiredis的实现,则读写超时是合在一起的,同一参数控制. 在hiredis中,读写超时调用函数redisSetTimeout设置,可以看到没有区分读 ...
- 【JZOJ6232】【20190625】喜欢最最痛
题目 \(n\)个节点的树,边权为正整数. 从1 号点开始走一个路径并最终回到 1 号点,且这条路径经过了所有的边. 一条路径的代价就是它经过的边的边权之和. 可以加若干条额外边,第 i 条加的额外边 ...
- pandas批量读取带有日期的文件夹简单操作
工作中碰到了这样一个数据处理的问题,想让你把某个文件夹下的子文件夹中的excel表级联成为1张表,用excel来做会很浪费时间并且很劳累,这时候我们就可以用pandas来加大工作效率,只需要半个小时就 ...
- python 判断操作系统以及操作系统版本号
>>> import platform >>> platform.platform() 'Darwin-17.7.0-x86_64-i386-64bit' > ...
- JavaScript 整数转大写中文
function toChinese(money){ var chNum=['零','壹','贰','叁','肆','伍','陆','柒','捌','玖']; var maxnum=999999999 ...
- R 语言输入输出 读取命令函参数
输入数据 使用键盘输入数据 只能处理小样本,很少使用 在创建 data.txt 字符串之后,用函数 read.table() 创建数据框 data.1.这种方法可以让我们把数据嵌入到R代码中,此处切记 ...
- 调用Fluent进行多工况计算总结
算例来源:https://confluence.cornell.edu/display/SIMULATION/FLUENT+-+Turbulent+Pipe+Flow 有时候我们对同一模型进行多工况计 ...
- jemalloc内存分配原理【转】
原文:http://www.cnblogs.com/gaoxing/p/4253833.html 内存分配是面向虚拟内存的而言的,以页为单位进行管理的,页的大小一般为4kb,当在堆里创建一个对象时(小 ...