Java线程操作方法
取得和设置线程名称
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:MyThread
// 属性:
// 方法:
class MyThread_1 implements Runnable{ //实现Runnable接口
private String name; // public MyThread_1(String name) { //构造方法
// super();
// this.name = name;
// } @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
for (int i=0;i<10;i++){
// System.out.println(name+"运行,i="+i);
System.out.println(Thread.currentThread().getName()+",i="+i); //取出当前线程的名称
}
} } //主类
//Function : Thread_demo
public class Runnable_demo { public static void main(String[] args) { MyThread_1 mt1 = new MyThread_1(); //实例化Runnable子类对象
new Thread(mt1).start(); //系统自动设置线程名称
new Thread(mt1,"线程A").start(); //手工自动设置线程名称
new Thread(mt1,"线程B").start(); //手工自动设置线程名称
new Thread(mt1).start(); //系统自动设置线程名称
new Thread(mt1).start(); //系统自动设置线程名称
} }
手工设置线程名称 系统自动设置线程名称
判断线程是否启动
使用isAlive()方法来判断线程是否已经启动而且仍然在启动
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:MyThread
// 属性:
// 方法:
class MyThread_1 implements Runnable{ //实现Runnable接口
private String name; public MyThread_1(String name) { //构造方法
super();
this.name = name;
} @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
for (int i=0;i<10;i++){
// System.out.println(name+"运行,i="+i);
System.out.println(Thread.currentThread().getName()+",i="+i); //取出当前线程的名称
}
} } //主类
//Function : Thread_demo
public class Runnable_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
MyThread_1 mt1 = new MyThread_1("线程A "); //实例化Runnable子类对象
MyThread_1 mt2 = new MyThread_1("线程B "); //实例化Runnable子类对象
Thread t1 = new Thread(mt1); //实例化Thread类对象
Thread t2 = new Thread(mt2); //实例化Thread类对象
System.out.println("线程开始执行之前-->"+t1.isAlive());
t1.start(); //启动线程
System.out.println("线程开始执行之后-->"+t1.isAlive());
t2.start(); //启动线程 } }
主线程有可能比其他线程先执行完
线程的强制运行
在线程操作中,可以使用join()方法让一个线程强制运行,线程强制运行期间,期间线程无法运行,必须等待此线程完成之后才可以继续执行。
线程的休眠
在程序中允许一个线程进行暂时的休眠,直接使用Thread.sleep()方法即可实现休眠
程序在执行的时候,每次的输出都会间隔500ms,达到了延时操作的效果。
Thread.sleep()方法要用try和catch语句包围
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:Mythread
// 属性:
// 方法:
class Mythread implements Runnable{ //实现Runnable接口 @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
for (int i=0;i<5;i++){
try{
Thread.sleep(500); //线程休眠
}catch (Exception e){} //需要异常处理
System.out.println(Thread.currentThread().getName()+",i="+i); //取出当前线程的名称
}
} } //主类
//Function : ThreadSleep_demo
public class ThreadSleep_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
Mythread m = new Mythread();
new Thread(m,"线程").start();
} }
中断线程
当一个线程运行时,另外一个线程可以直接通过interrupt()方法中断其运行状态。
一个线程启动之后进入了休眠状态,原来是要休眠10s之后再继续执行,但是主方法在线程启动之后的2s之后就将其中断,休眠一旦中断之后将执行catch中的代码。
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:Mythread_1
// 属性:
// 方法:
class Mythread_1 implements Runnable{ //实现Runnable接口 @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
System.out.println("进入run方法");
try{
Thread.sleep(10000); //线程休眠
System.out.println("休眠完成");
}catch (Exception e){ //需要异常处理
System.out.println("休眠被终止");
return; //让程序返回被调用处
}
System.out.println("run方法结束");
} } //主类
//Function : ThreadSleep_demo
public class ThreadInterrupt_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
Mythread_1 m = new Mythread_1();
Thread t = new Thread(m,"线程");
t.start();
try{
Thread.sleep(2000); //主线程2s之后再执行中断
}catch(Exception e){}
t.interrupt();
} }
后台线程
在Java程序中,只要前台有一个线程在运行,则整个Java进程都不会消失,所以此时可以设置一个后台线程,这样即使Java进程结束了,此后台线程依然会继续执行。要想实现这样的操作,直接使用setDaemon()方法即可。
线程的优先级
在Java的线程中使用setPriority()方法可以设置一个线程的优先级,在Java的线程中一共有3种优先级。
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:MyThread
// 属性:
// 方法:
class MyThread_1 implements Runnable{ //实现Runnable接口
private String name; // public MyThread_1(String name) { //构造方法
// super();
// this.name = name;
// } @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
for (int i=0;i<10;i++){
//System.out.println(name+"运行,i="+i);
System.out.println(Thread.currentThread().getName()+",i="+i); //取出当前线程的名称
}
} } //主类
//Function : Thread_demo
public class Runnable_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
MyThread_1 mt1 = new MyThread_1(); //实例化Runnable子类对象
MyThread_1 mt2 = new MyThread_1(); //实例化Runnable子类对象
MyThread_1 mt3 = new MyThread_1(); //实例化Runnable子类对象
Thread t1 = new Thread(mt1,"线程A"); //实例化Thread类对象
Thread t2 = new Thread(mt2,"线程B"); //实例化Thread类对象
Thread t3 = new Thread(mt3,"线程C"); //实例化Thread类对象
// System.out.println("线程开始执行之前-->"+t1.isAlive());
t1.setPriority(Thread.MIN_PRIORITY);
t2.setPriority(Thread.NORM_PRIORITY);
t3.setPriority(Thread.MAX_PRIORITY);
t1.start(); //启动线程
// System.out.println("线程开始执行之前-->"+t1.isAlive());
t2.start(); //启动线程
t3.start(); //启动线程 // MyThread_1 mt1 = new MyThread_1(); //实例化Runnable子类对象
// new Thread(mt1).start(); //系统自动设置线程名称
// new Thread(mt1,"线程A").start(); //手工自动设置线程名称
// new Thread(mt1,"线程B").start(); //手工自动设置线程名称
// new Thread(mt1).start(); //系统自动设置线程名称
// new Thread(mt1).start(); //系统自动设置线程名称
} }
线程将根据优先级的大小来决定哪个线程会先运行,但是并非线程的优先级越高就一定会先执行,哪个线程先执行将由CPU的调度决定。
主方法的优先级是NORM,通过Thread.currentThread().getPriority()来取得主方法的优先级,结果是5
线程的礼让
在线程的操作中,可以使用yield()方法将一个线程的操作暂时让给其他线程执行。本线程暂停,让其他进程先执行。
//=================================================
// File Name : Thread_demo
//------------------------------------------------------------------------------
// Author : Common // 接口名:MyThread
// 属性:
// 方法:
class MyThread_1 implements Runnable{ //实现Runnable接口
private String name; // public MyThread_1(String name) { //构造方法
// super();
// this.name = name;
// } @Override
public void run() { //覆写Thread类中的run()方法
// TODO 自动生成的方法存根
for (int i=0;i<10;i++){
//System.out.println(name+"运行,i="+i);
System.out.println(Thread.currentThread().getName()+",i="+i); //取出当前线程的名称
if(i==3){
System.out.println("线程礼让:");
Thread.currentThread().yield(); //线程礼让
}
}
} } //主类
//Function : Thread_demo
public class Runnable_demo { public static void main(String[] args) {
// TODO 自动生成的方法存根
MyThread_1 mt1 = new MyThread_1(); //实例化Runnable子类对象
MyThread_1 mt2 = new MyThread_1(); //实例化Runnable子类对象
MyThread_1 mt3 = new MyThread_1(); //实例化Runnable子类对象
Thread t1 = new Thread(mt1,"线程A"); //实例化Thread类对象
Thread t2 = new Thread(mt2,"线程B"); //实例化Thread类对象
Thread t3 = new Thread(mt3,"线程C"); //实例化Thread类对象
// System.out.println("线程开始执行之前-->"+t1.isAlive());
t1.setPriority(Thread.MIN_PRIORITY);
t2.setPriority(Thread.NORM_PRIORITY);
t3.setPriority(Thread.MAX_PRIORITY);
t1.start(); //启动线程
// System.out.println("线程开始执行之前-->"+t1.isAlive());
t2.start(); //启动线程
t3.start(); //启动线程 // MyThread_1 mt1 = new MyThread_1(); //实例化Runnable子类对象
// new Thread(mt1).start(); //系统自动设置线程名称
// new Thread(mt1,"线程A").start(); //手工自动设置线程名称
// new Thread(mt1,"线程B").start(); //手工自动设置线程名称
// new Thread(mt1).start(); //系统自动设置线程名称
// new Thread(mt1).start(); //系统自动设置线程名称
} }
线程礼让也是不一定的
Java线程操作方法的更多相关文章
- 【转载】深度解读 java 线程池设计思想及源码实现
总览 开篇来一些废话.下图是 java 线程池几个相关类的继承结构: 先简单说说这个继承结构,Executor 位于最顶层,也是最简单的,就一个 execute(Runnable runnable) ...
- Java并发指南12:深度解读 java 线程池设计思想及源码实现
深度解读 java 线程池设计思想及源码实现 转自 https://javadoop.com/2017/09/05/java-thread-pool/hmsr=toutiao.io&utm_ ...
- Java线程并发:知识点
Java线程并发:知识点 发布:一个对象是使它能够被当前范围之外的代码所引用: 常见形式:将对象的的引用存储到公共静态域:非私有方法中返回引用:发布内部类实例,包含引用. 逃逸:在对象尚未准备 ...
- Java线程的概念
1. 计算机系统 使用高速缓存来作为内存与处理器之间的缓冲,将运算需要用到的数据复制到缓存中,让计算能快速进行:当运算结束后再从缓存同步回内存之中,这样处理器就无需等待缓慢的内存读写了. 缓 ...
- Java 线程池框架核心代码分析--转
原文地址:http://www.codeceo.com/article/java-thread-pool-kernal.html 前言 多线程编程中,为每个任务分配一个线程是不现实的,线程创建的开销和 ...
- 细说进程五种状态的生老病死——双胞胎兄弟Java线程
java线程的五种状态其实要真正高清,只需要明白计算机操作系统中进程的知识,原理都是相同的. 系统根据PCB结构中的状态值控制进程. 单CPU系统中,任一时刻处于执行状态的进程只有一个. 进程的五种状 ...
- 【转载】 Java线程面试题 Top 50
Java线程面试题 Top 50 不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题.Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员 的欢迎.大多数待遇丰厚的J ...
- 第24章 java线程(3)-线程的生命周期
java线程(3)-线程的生命周期 1.两种生命周期流转图 ** 生命周期:**一个事物冲从出生的那一刻开始到最终死亡中间的过程 在事物的漫长的生命周期过程中,总会经历不同的状态(婴儿状态/青少年状态 ...
- 第23章 java线程通信——生产者/消费者模型案例
第23章 java线程通信--生产者/消费者模型案例 1.案例: package com.rocco; /** * 生产者消费者问题,涉及到几个类 * 第一,这个问题本身就是一个类,即主类 * 第二, ...
随机推荐
- .Net Core 1.0.0 RC2安装及示例教程
前几天微软发布了.Net Core1.0.0 RC2 Preview版本,一直都想尝试下跨平台的.Net Core,一直拖到今天,也参考了下园友们的经验,闲时整理了一下安装的步骤,供大家参考. 我们要 ...
- Entity Framework Code First (四)Fluent API - 配置属性/类型
上篇博文说过当我们定义的类不能遵循约定(Conventions)的时候,Code First 提供了两种方式来配置你的类:DataAnnotations 和 Fluent API, 本文将关注 Flu ...
- bzoj1012
Description 现在请求你维护一个数列,要求提供以下两种操作:1. 查询操作.语法:Q L 功能:查询当前数列中末尾L 个数中的最大的数,并输出这个数的值.限制:L不超过当前数列的长度.2. ...
- SSD固态硬盘的闪存芯片颗粒介绍
固态硬盘凭借其存取速率超快等自身优势,被越来越多的电脑爱好者所青睐,并迅速普及到了广大用户的电脑中,因为固态硬盘与传统机械硬盘相比,确实在运行效率等方面有了质的提升,这里先了解一些评判固态硬盘优劣的知 ...
- 如何生成HTMLTestRunner报告
今天,学习了如何生成HTMLTestRunner测试报告. 接上篇文章,对于unittest框架,运行后,测试结果不便于查看,同时多个case存在的时候,可能会导致case result记录不正确的情 ...
- 在MAC上搭建tomcat,再使用servlet时遇到的问题。
说起来真是惭愧.在mac上配置tomcat环境时.tomcat6能正确运行.但是7,8都运行不了.具体表现是tomcat6访问127.0.0.1:8080可以显示那个界面,然而tomcat7和8都显示 ...
- Tomcat安装
第一步,下载: 直接上下载地址:http://tomcat.apache.org/download-70.cgi 直接下载如下选中即可: 第二步,安装: 然后解压(这里我是放在下载里),再进入bin目 ...
- Mysql修改root用户密码 For Mac 报错:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
环境 Mysql版本:5.7.12 操作系统:OSX 10.11 安装文件:.dmg文件 MySQL:mysql-5.7.12-osx10.11-x86_64.dmg(注意5.7跟之前的字段有些不同, ...
- perl sub return 的作用
test_1.pl #/usr/bin/perl -w use strict; print add(1,2),"\n"; sub add { my ($x,$y) = @_; re ...
- C#位操作与枚举的应用
看到代码里有用位操作来判断条件的,以前没有这么用过,做个笔记: int add = 2; int modify = 4; int delete = 8; Console.WriteLine((add ...