文档章节

学习笔记4:java中Thread类的方法小结

牧羊人Berg
 牧羊人Berg
发布于 2015/10/16 10:59
字数 597
阅读 53
收藏 3

稍稍对Thread类中的常用方法简单地做了一次总结,加深点印象。  

仍然还是采用继承Thread类的案例来实现创建线程的方式 , 附代码段: 

/*
 * @auto: 牧羊的伯格女皇
 * 2015-10-16
 * Thread的常用方法稍微总结:
 * 1. start() 启动线程并执行相应的run()方法
 * 2. run()  子线程要执行的代码放入run()方法中
 * 3. currentThread() 静态的, 调取当前的线程,即返回对当前正在执行的线程对象的引用。
 * 4. getName(): 获取此线程的名字
 * 5. setName(): 设置此线程的名字
 * 6. yield()  : 暂停当前正在执行的线程对象,并执行其他线程。即调用此方法的线程释放对当前CPU的占用权,退让使用权。
 * 7. join() :等待该线程终止。即在A线程中调用B线程的join()方法,表示当执行到此方法,A线程停止执行,直至B线程执行完毕,
 * 				A线程再接着join()之后的代码执行
 * 8. isAlive() : 判断当前线程是否还存活 ,布尔值,如果是死亡状态返回false
 * 9. sleep(long m) 显示的让当前线程睡眠 m 毫秒 记住:被重写的方法不能比父类抛更大的异常。
 * 10. 线程通信中的三个方法: wait()  notify()   notifyAll() 
 * 
 * 11. 设置线程的优先级:高优先级线程先抢占cpu 
 * 		       getProority(): 返回线程优先值
 * 		       setProority(int newProority) : 改变线程的优先级
 * */
 
 
class SubThread extends Thread {
	@Override
	public void run() {
		for( int i=0; i<=100; i++ ){
			try {
				// 被重写的方法不能比父类抛出更大的异常 。 所以只能try-catch
				Thread.currentThread().sleep( 1000 );
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
			System.out.println( Thread.currentThread().getName() +": " + Thread.currentThread().getPriority() +": " + i );
		}
	}
	
}

class TestThread{
	public static void main(String[] args) {  //隐含的主线程
		Thread.currentThread().setName("==========main主线程"); // 给主线程设置线程名称
		SubThread st = new SubThread();
		st.setName("  子线程");  // 给子线程设置名称
		st.setPriority( Thread.MAX_PRIORITY );  // 设置子线程为最高优先级 ,  10   默认为5  最小为 1 
		st.start();
		for( int i=0; i<=100; i++ ){
			System.out.println( Thread.currentThread().getName() +": " + Thread.currentThread().getPriority() +": " + i );
//			if( i % 10 == 0 ){
//				System.out.println("暂停主线程,执行子线程:");
//				Thread.currentThread().yield();
//			}
			
			/*
			if( i == 30 ){
				System.out.println("开始暂停主线程,并执行子线程:");
				try {
					st.join();
					System.out.println("等待子线程执行完毕,再接着执行主线程:");
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
			}
			*/
		}
		System.out.println("查看子线程st是否还存活:  " + st.isAlive() );
	}
}




© 著作权归作者所有

共有 人打赏支持
牧羊人Berg
粉丝 24
博文 96
码字总数 87512
作品 0
深圳
私信 提问
加载中

评论(2)

牧羊人Berg
牧羊人Berg

引用来自“抽象派”的评论

实际用的话,线程同步都是通过锁来实现的,尽量避免线程通信,实在要通信的话也是使用消息队列。
还有个比较常用的是,Thread.sleep(1)和setDaemon(true)。

嗯嗯,受教了。 至于线程同步,锁,消息队列等方面内容我还没看。
_wxyz
_wxyz
实际用的话,线程同步都是通过锁来实现的,尽量避免线程通信,实在要通信的话也是使用消息队列。
还有个比较常用的是,Thread.sleep(1)和setDaemon(true)。
读书笔记之《Java并发编程的艺术》-并发编程容器和框架(重要)

读书笔记部分内容来源书出版书,版权归本书作者,如有错误,请指正。 欢迎star、fork,读书笔记系列会同步更新 git https://github.com/xuminwlt/j360-jdk module j360-jdk-thread/me.j360....

Hi徐敏
2015/11/11
0
1
读书笔记之《Java并发编程的艺术》-线程池和Executor的子孙们

读书笔记部分内容来源书出版书,版权归本书作者,如有错误,请指正。 欢迎star、fork,读书笔记系列会同步更新 git https://github.com/xuminwlt/j360-jdk module j360-jdk-thread/me.j360....

Hi徐敏
2015/11/11
0
1
读书笔记之《Java并发编程的艺术》-并发编程基础

读书笔记部分内容来源书出版书,版权归本书作者,如有错误,请指正。 欢迎star、fork,读书笔记系列会同步更新 git https://github.com/xuminwlt/j360-jdk module j360-jdk-thread/me.j360....

Hi徐敏
2015/11/11
0
8
[转]理解ThreadLocal

ThreadLocal是什么 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类可以很简洁地编写出优美的多线程程序。 Th...

inferrrrrr
2009/11/03
0
0
转:理解ThreadLocal

ThreadLocal是什么 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类可以很简洁地编写出优美的多线程程序。 Th...

轮回今生
2012/10/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Ubuntu常用操作

查看端口号 netstat -anp |grep 端口号 查看已使用端口情况 netstat -nultp(此处不用加端口号) netstat -anp |grep 82查看82端口的使用情况 查找被占用的端口: netstat -tln netstat -tl...

hc321
昨天
1
0
网站cdn的静态资源突然访问变的缓慢,问题排查流程

1.首先我查看了一下是否自己的网络问题,通过对比其他资源的访问速度和下载速度,确认不是 2.通过ping 和 tracert 判断cdn域名能否正常访问,(最后回想感觉这一步可以省略,因为每次最终能访...

小海bug
昨天
0
0
Mybatis 学习笔记四 MyBatis-Plus插件

Mybatis 学习笔记四 MyBatis-Plus插件 maven依赖 <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <ve......

晨猫
昨天
4
0
小白带你认识netty(二)之netty服务端启动(下)

承接上一篇小白带你认识netty(二)之netty服务端启动(上),还剩下两步骤:3、注册Selector:将Channel注册到Selector上 和 4、端口的绑定:服务端端口的监听。 3、注册Selector:将Chann...

天空小小
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部