会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132911个问题

老师,我按照视频上老师的方法敲了代码,运行都没问题,但是突然发现,这个程序并没有自动结束,IDEAL中的红色方块一直亮着,如下图:

0f6ec0316320147f37a1f9cdcf5e5f5.png

麻烦老师帮忙看看是怎么回事,具体代码粘贴如下:

1.Printer类代码

package com.bjsxt.thread;

public class Printer {
    private int index=1;//用于统计第几次打印
    public synchronized void print(int number){
        while(index%3==0){
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        System.out.print(number);
        index++;
        super.notifyAll();//唤醒所有在printer这个对象上所有等待的线程
    }
    public synchronized void print(char letter){
        while(index%3!=0){
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        System.out.print(""+letter);
        index++;
        super.notifyAll();
    }
}

2.数字打印类代码

package com.bjsxt.thread;

public class NumberPrinter implements Runnable {
    private Printer printer;

    public NumberPrinter(Printer printer) {
        this.printer=printer;
    }

    @Override
    public void run() {
        for(int i=1;i<=52;i++){
            printer.print(i);
        }
    }
}

3.字母打印类代码

package com.bjsxt.thread;

public class LetterPrinter implements Runnable{
    private Printer printer;
    public LetterPrinter(Printer printer){
        this.printer=printer;
    }    @Override
    public void run() {
        for(char c='A';c<='z';c++){
          printer.print(c);
        }
    }
}

4.主线程测试代码

package com.bjsxt.thread;

public class Test {
    public static void main(String[] args) {
        //创建共享资源的对象
        Printer p=new Printer();
        NumberPrinter np=new NumberPrinter(p);
        LetterPrinter lp=new LetterPrinter(p);
        //创建代理类,并启动线程
        new Thread(np).start();
        new Thread(lp).start();
    }
}


JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程和并发编程(旧) 29462楼
JAVA 全系列/第六阶段:项目管理与SSM框架/Mybatis 29464楼
Python 全系列/第九阶段:Flask百战电商后台系统/Flask百战电商后台项目 29465楼
JAVA 全系列/第一阶段:JAVA 快速入门/变量、数据类型、运算符 29466楼
JAVA 全系列/第五阶段:JavaWeb开发/Servlet技术详解 29469楼
JAVA 全系列/第八阶段:Linux入门到实战/Maven 29470楼

1.用的老师源码,报错。我用的是tomcat9

Connected to server

[2021-04-06 09:37:13,595] Artifact rbacdemo:war exploded: Artifact is being deployed, please wait...

06-Apr-2021 21:37:15.654 信息 [RMI TCP Connection(3)-127.0.0.1] org.apache.jasper.servlet.TldScanner.scanJars 至少有一个JAR被扫描用于TLD但尚未包含TLD。 为此记录器启用调试日志记录,以获取已扫描但未在其中找到TLD的完整JAR列表。 在扫描期间跳过不需要的JAR可以缩短启动时间和JSP编译时间。

log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).

log4j:WARN Please initialize the log4j system properly.

log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

06-Apr-2021 21:37:18.114 严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.startInternal 一个或多个listeners启动失败,更多详细信息查看对应的容器日志文件

06-Apr-2021 21:37:18.115 严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.startInternal 由于之前的错误,Context[]启动失败

06-Apr-2021 21:37:18.130 警告 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.loader.WebappClassLoaderBase.clearReferencesJdbc Web应用程序 [ROOT] 注册了JDBC驱动程序 [com.mysql.jdbc.Driver],但在Web应用程序停止时无法注销它。 为防止内存泄漏,JDBC驱动程序已被强制取消注册。

[2021-04-06 09:37:18,142] Artifact rbacdemo:war exploded: Error during artifact deployment. See server log for details.

06-Apr-2021 21:37:23.416 信息 [Catalina-utility-1] org.apache.catalina.startup.HostConfig.deployDirectory 把web 应用程序部署到目录 [D:\apache-tomcat-9.0.34\webapps\manager]

06-Apr-2021 21:37:23.503 信息 [Catalina-utility-1] org.apache.catalina.startup.HostConfig.deployDirectory Deployment of web application directory [D:\apache-tomcat-9.0.34\webapps\manager] has finished in [87] ms


2.源码

rbacdemo.rar


JAVA 全系列/第六阶段:项目管理与SSM框架/RBAC实战 29471楼
JAVA 全系列/第十一阶段:消息中间件与高并发处理/RabbitMQ 29472楼
JAVA 全系列/第十一阶段:消息中间件与高并发处理/Nginx 29473楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术 29475楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637