热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

这种行为背后的原因是什么(线程)

我正在研究线程,并决定在运行我的重点代码行之前和之后添加一些额外的文本

我正在研究线程,并决定在运行我的重点代码行之前和之后添加一些额外的文本,以供参考。我期望在开始时获得一个“额外文本”,而在结束时获得另一个。但是...没有发生,当我运行它时,第二个“额外文本”仅位于第四位置。我是初学者,需要知道为什么会这样...

--- CODE ---

class Hi extends Thread{
public void run(){
for(int i=1; i<=5; i++){
System.out.println("HI!");
try{
Thread.sleep(500);
} catch(InterruptedException e){}
}
}
}
class Hey extends Thread{
public void run(){
for(int i=1; i<=5; i++){
System.out.println("HEY!");
try{
Thread.sleep(500);
} catch(InterruptedException e){}
}
}
}
public class MyClass {
public static void main(String[] args){
Hi hiObj = new Hi();
Hey heyObj = new Hey();
System.out.println("extra-text");
hiObj.start();
heyObj.start();
try {
Thread.currentThread().sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("extra-text");
}
}

---输出---

extra-text
HI!
HEY!
extra-text
HEY!
HI!
HEY!
HI!
HEY!
HI!
HEY!
HI!



这是常见的并发错误。

程序的主方法在主线程上运行。因此,在启动hiObjheyObj线程之前,您已经有一个线程。启动两个新线程后,您将拥有三个。每个都同时执行。这意味着每个线程可以执行代码而无需等待其他线程。不能保证线程之间的顺序。

这会导致您观察到的行为。在启动hiObjheyObj之前,在主线程上运行的main方法将打印"extra-text"。接下来,启动hiObj和heyObj。主线程到达行Thread.currentThead().sleep(10),这导致它暂停执行10毫秒。在大多数计算机(包括您的计算机)上,这足以让其他两个线程开始执行。每个线程都以其for方法开始run循环,并打印"HI""HEY"。因此,输出的前三行是(不保证"HI""HEY"的顺序):

"extra-text"

"HI"

"HEY"

接下来,hiObjheyObj线程到达行Thread.sleep(500),这使它们暂停执行500毫秒。经过10毫秒后,主线程将完成睡眠并恢复运行。请注意,hiObjheyObj线程现在都无法恢复。因此,打印的下一行将是在main中执行的下一行的。这是"extra-text"。因此,预期输出为:

"extra-text"

"HI"

"HEY"

"extra-text"

在接下来的几秒钟内,将发生hiObjheyObj线程中的其余打印。在Java中,主线程仅在所有其他线程都退出之后退出(除非调用System.exit或存在未捕获的异常)。在这种情况下,这意味着程序仅在main到达执行结束时以及hiObjheyObj的run方法都返回时退出。

要更改程序,以使最后的"extra-text"始终显示在末尾,则必须使主线程等待hiObjheyObj线程完成。在Java中,Thead上有一个名为join的方法,该方法使调用线程等待,直到连接的线程死亡。在程序中,您可以将MyClass修改为如下形式:

public class MyClass {
public static void main(String[] args){
Hi hiObj = new Hi();
Hey heyObj = new Hey();
System.out.println("extra-text");
hiObj.start();
heyObj.start();
try {
Thread.currentThread().sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
hiObj.join();
heyObj.join();
System.out.println("extra-text");
}
}

进行此更改后,main将首先等待hiObj完成,然后等待heyObj完成,然后再打印"extra-text"

,

如果您摆脱

Thread.currentThread().sleep(10);

在主方法中,您将看到执行后立即将另外两个文本打印到控制台。通过使用sleep(10),您只需延迟第二个额外的文本,与此同时,您的2个线程将打印其第一个输出。


推荐阅读
  • 问题场景用Java进行web开发过程当中,当遇到很多很多个字段的实体时,最苦恼的莫过于编辑字段的查看和修改界面,发现2个页面存在很多重复信息,能不能写一遍?有没有轮子用都不如自己造。解决方式笔者根据自 ... [详细]
  • 本文详细介绍了 `org.apache.tinkerpop.gremlin.structure.VertexProperty` 类中的 `key()` 方法,并提供了多个实际应用的代码示例。通过这些示例,读者可以更好地理解该方法在图数据库操作中的具体用途。 ... [详细]
  • 处理Android EditText中数字输入与parseInt方法
    本文探讨了如何在Android应用中从EditText组件安全地获取并解析用户输入的数字,特别是用于设置端口号的情况。通过示例代码和异常处理策略,展示了有效的方法来避免因非法输入导致的应用崩溃。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • Beetl是一款先进的Java模板引擎,以其丰富的功能、直观的语法、卓越的性能和易于维护的特点著称。它不仅适用于高响应需求的大型网站,也适合功能复杂的CMS管理系统,提供了一种全新的模板开发体验。 ... [详细]
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • 想把一组chara[4096]的数组拷贝到shortb[6][256]中,尝试过用循环移位的方式,还用中间变量shortc[2048]的方式。得出的结论:1.移位方式效率最低2. ... [详细]
  • 本文深入探讨了WPF框架下的数据验证机制,包括内置验证规则的使用、自定义验证规则的实现方法、错误信息的有效展示策略以及验证时机的选择,旨在帮助开发者构建更加健壮和用户友好的应用程序。 ... [详细]
  • Zabbix自定义监控与邮件告警配置实践
    本文详细介绍了如何在Zabbix中添加自定义监控项目,配置邮件告警功能,并解决测试告警时遇到的邮件不发送问题。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文详细探讨了在Java编程语言中,构造函数、静态代码块和构造代码块的执行顺序。首先明确了静态代码块、构造代码块以及构造函数方法体的执行优先级,随后深入分析了构造函数体执行前的具体步骤,包括父类构造器的调用、非静态变量的初始化等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • Java 中的十进制样式 getZeroDigit()方法,示例 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • 本文介绍了如何通过C#语言调用动态链接库(DLL)中的函数来实现IC卡的基本操作,包括初始化设备、设置密码模式、获取设备状态等,并详细展示了将TextBox中的数据写入IC卡的具体实现方法。 ... [详细]
author-avatar
总裁班的草根
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有