java多线程的常用方法
2024-10-16 01:08:16
介绍一些多线程中的常用方法:
//启动方法
a.start(); //返回代码正在被哪个线程调用的信息
a.currentThread(); //返回线程的名字
a.currentThread().getName(); //判断线程是否处于存活状态
a.isAlive(); //线程延迟 单位毫秒
a.sleep(); //取得线程的唯一标识
a.getId();
暂停继续:
//让线程以毫秒进入阻塞状态,等到时间一过,正常运行
a.sleep(300);
suspend()和 resume()方法:
线程的暂停和恢复,使用 suspend()方法使线程进入阻塞状态,不可以自动恢复,可使用resume()方法将线程唤醒。
yield()方法:
yield()方法的作用是放弃当前CPU资源,将他让给其他的任务去使用,但是放弃的时间是不确定的,有可以刚刚放弃,马上又得到CPU的使用时间。
下面写段代码举个例子:
不使用yield()方法执行:
public class Test01 extends Thread { @Override
public void run() {
super.run();
long beginTime = System.currentTimeMillis();
for (int i = 0; i < 10000; i++) {
System.out.println(i++);
}
long endTime = System.currentTimeMillis();
System.out.println("执行完成,用时:" + (endTime - beginTime) + "毫秒!");
} public static void main(String[] args) {
Test01 thread = new Test01();
thread.start();
}
} //打印结果 9990
9992
9994
9996
9998
执行完成,用时:37毫秒!
使用yield()方法执行:
public class Test01 extends Thread { @Override
public void run() {
super.run();
long beginTime = System.currentTimeMillis();
for (int i = 0; i < 10000; i++) {
//使用yield()方法放弃CPU时间
this.yield();
System.out.println(i++);
}
long endTime = System.currentTimeMillis();
System.out.println("执行完成,用时:" + (endTime - beginTime) + "毫秒!");
} public static void main(String[] args) {
Test01 thread = new Test01();
thread.start();
}
} //打印结果 9984
9986
9988
9990
9992
9994
9996
9998
执行完成,用时:241毫秒!
事实证明,执行yield()方法把CPU时间给其他程序,会使此程序执行效率变慢。
最新文章
- 2016HDU校赛
- Centos6.6下安装MariaDB步骤,利用yum进行安装
- BZOJ 4544: 椭圆上的整点
- Hexo搭建Github静态博客
- JMeter学习(五)检查点
- PAT乙级 1025. 反转链表 (25)
- 哈夫曼(Huffman)编码
- JavaScript下拉框去除重复内容
- Android开源项目发现--- 工具类文件处理篇(持续更新)
- PHP7中我们应该学习会用的新特性
- MySQLzip archive版本(5.7.19)安装教程
- [ExtJS5学习笔记]第十六节 Extjs5使用panel新增的ViewModel属性绑定数据
- SwipeListView 详解 实现微信,QQ等滑动删除效果
- 【kindle笔记】读书记录-总
- 让table中td的内容靠上对齐
- wsl install lamp
- unity中实现简单对象池,附教程原理
- 开发webapp手机返回键 退出问题 摘录
- Vue.js系列之二Vue实例
- 1087. [SCOI2005]互不侵犯King【状压DP】