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

《Java核心技术卷1》笔记第11章异常、日志、断言和调试(9)自制控制台窗口与窗口事件抓取

 11.6.1 使用控制台窗口 调试时,因为信息较多,比起机器捕捉关键词,有时人眼直接捕捉会更有效率。此时就需要滚动的窗口,而非 cmd

 11.6.1 使用控制台窗口

调试时,因为信息较多,比起机器捕捉关键词,有时人眼直接捕捉会更有效率。此时就需要滚动的窗口,而非 cmd,terminal 之类的简易控制台。就可带滚动条继续打印 System.out/System.err的内容。

修订版(作者弄得白背景黑字感觉不像,自己调了一下):

 ConsoleWindow.java

🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎

import javax.swing.*;
import javax.swing.text.BadLocationException;
import javax.swing.text.SimpleAttributeSet;
import javax.swing.text.StyleConstants;
import javax.swing.text.StyledDocument;
import java.awt.*;
import java.io.OutputStream;
import java.io.PrintStream;public class ConsoleWindow {private static final int W = 800;private static final int H = 500;private static final int L = 200;private static final int T = 200;public static void init(){JFrame frame = new JFrame();frame.setTitle("ConsoleWindow");final JTextPane output = new JTextPane();output.setEditable(false);frame.add(new JScrollPane(output));frame.setSize(W,H);frame.setLocation(L,T);frame.setFocusableWindowState(false);frame.setVisible(true);output.setBackground(Color.BLACK);output.setFont(new Font("DIALOG",Font.BOLD,20));StyledDocument d = output.getStyledDocument();SimpleAttributeSet attr = new SimpleAttributeSet();PrintStream consoleStream = new PrintStream(new OutputStream(){@Overridepublic void write(int b) {}public void write(byte[] b, int off, int len) {StyleConstants.setForeground(attr,Color.WHITE);try {d.insertString(d.getLength(),new String(b,off,len),attr);} catch (BadLocationException e) {e.printStackTrace();}}});new Font("",Font.BOLD,5);PrintStream consoleStream2 = new PrintStream(new OutputStream(){@Overridepublic void write(int b) {}public void write(byte[] b, int off, int len){StyleConstants.setForeground(attr,Color.RED);try {d.insertString(d.getLength(),new String(b,off,len),attr);} catch (BadLocationException e) {e.printStackTrace();}}});System.setOut(consoleStream);System.setErr(consoleStream2);}
}

🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎

 

 Main.java

🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎🧡💛💚💙💜🖤🤎

public class Main {public static void main(String[] args) {Main solution &#61; new Main();ConsoleWindow.init();for(int i &#61; 0; i <10; i&#43;&#43;){System.out.println("out "&#43;i);System.err.println("err "&#43;i);}}
}

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

 

 

 

 

 11.6.2 跟踪 AWT 事件

 

我们希望当 AWT 组件和用户交互过程中&#xff0c;能显示提示信息&#xff0c;应该捕获信息&#xff0c;并将状态信息进行输出。

这部分挺有意思的&#xff0c;大致就是作者通过事件描述符&#xff0c;拦截到事件&#xff0c;然后交给代理类去处理&#xff0c;然后代理类完成了输出工作。为了和前面的内容结合&#xff0c;又把刚刚的控制台利用上了。这个控制台不会自动换行&#xff0c;内容一长看的头疼。找了好久&#xff0c;终于让我找到一个设置自动换行的工具&#xff0c;MyHTMLEditorKit&#xff1a;

 

 MyHTMLEditorKit.class

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

import javax.swing.*;
import javax.swing.text.Element;
import javax.swing.text.ParagraphView;
import javax.swing.text.View;
import javax.swing.text.ViewFactory;
import javax.swing.text.html.HTMLEditorKit;
import javax.swing.text.html.InlineView;public class MyHTMLEditorKit extends HTMLEditorKit {private static final long serialVersionUID &#61; 3632670469611941371L;&#64;Overridepublic ViewFactory getViewFactory() {return new HTMLFactory() {public View create(Element e) {View v &#61; super.create(e);if (v instanceof InlineView) {return new InlineView(e) {public int getBreakWeight(int axis, float pos, float len) {return GoodBreakWeight;}public View breakView(int axis, int p0, float pos, float len) {if (axis &#61;&#61; View.X_AXIS) {checkPainter();int p1 &#61; getGlyphPainter().getBoundedPosition(this, p0, pos, len);if (p0 &#61;&#61; getStartOffset() && p1 &#61;&#61; getEndOffset()) {return this;}return createFragment(p0, p1);}return this;}};} else if (v instanceof ParagraphView) {return new ParagraphView(e) {protected SizeRequirements calculateMinorAxisRequirements(int axis,SizeRequirements r) {if (r &#61;&#61; null) {r &#61; new SizeRequirements();}float pref &#61; layoutPool.getPreferredSpan(axis);float min &#61; layoutPool.getMinimumSpan(axis);r.minimum &#61; (int) min;r.preferred &#61; Math.max(r.minimum, (int) pref);r.maximum &#61; Integer.MAX_VALUE;return r;}};}return v;}};}
}

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

 

 ConsoleWindow.class

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

import javax.swing.*;
import javax.swing.text.*;
import java.awt.*;
import java.io.OutputStream;
import java.io.PrintStream;public class ConsoleWindow {private static final int W &#61; 800;private static final int H &#61; 500;private static final int L &#61; 200;private static final int T &#61; 200;public static void init(){EventTracer tracer &#61; new EventTracer();JFrame frame &#61; new JFrame();tracer.add(frame);frame.setTitle("ConsoleWindow");final JTextPane output &#61; new JTextPane();output.setEditorKit(new MyHTMLEditorKit());output.setEditable(false);output.setSize(W,H);frame.add(new JScrollPane(output));frame.setSize(W,H);frame.setLocation(L,T);frame.setFocusableWindowState(false);frame.setVisible(true);output.setBackground(Color.BLACK);output.setFont(new Font("DIALOG",Font.BOLD,20));StyledDocument d &#61; output.getStyledDocument();SimpleAttributeSet attr &#61; new SimpleAttributeSet();PrintStream consoleStream &#61; new PrintStream(new OutputStream(){&#64;Overridepublic void write(int b) {}public void write(byte[] b, int off, int len) {StyleConstants.setForeground(attr,Color.WHITE);try {d.insertString(d.getLength(),new String(b,off,len),attr);} catch (BadLocationException e) {e.printStackTrace();}}});new Font("",Font.BOLD,5);PrintStream consoleStream2 &#61; new PrintStream(new OutputStream(){&#64;Overridepublic void write(int b) {}public void write(byte[] b, int off, int len){StyleConstants.setForeground(attr,Color.RED);try {d.insertString(d.getLength(),new String(b,off,len),attr);} catch (BadLocationException e) {e.printStackTrace();}}});System.setOut(consoleStream);System.setErr(consoleStream2);}
}

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

 Main.java

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

 

public class Main {public static  void main(String[] args) {Main solution &#61; new Main();ConsoleWindow.init();}}

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

 

 

然后发现书的作者还有第二段代码。。。嗯~ o(*&#xffe3;▽&#xffe3;*)o&#xff0c;跑偏了。那就再试下呗。

 

 

给了个滚动条&#xff0c;还有个按钮&#xff0c;咱把刚刚的控制台再加进来&#xff0c;来个三级运载火箭合体&#xff1a;

 

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

import javax.swing.*;
import java.awt.*;public class EventTracerTest {public static void main(String[] args) {EventQueue.invokeLater(new Runnable() {&#64;Overridepublic void run() {JFrame frame &#61; new EventTracerFrame();frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);frame.setVisible(true);}});}
}class EventTracerFrame extends JFrame{private static final int W &#61; 400;private static final int H &#61; 400;public EventTracerFrame(){setTitle("EventTracerTest");setSize(W,H);add(new JSlider(),BorderLayout.NORTH);add(new JButton("Test"),BorderLayout.SOUTH);ConsoleWindow.init();EventTracer tracer &#61; new EventTracer();tracer.add(this);}
}

&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;&#x1f9e1;&#x1f49b;&#x1f49a;&#x1f499;&#x1f49c;&#x1f5a4;&#x1f90e;

控制台代码的这两行屏蔽一下&#xff1a;

 

 

相关内容&#xff1a;选择 《Java核心技术 卷1》查找相关笔记

评论&#x1f339;点赞&#x1f44d;收藏✨关注&#x1f440;&#xff0c;是送给作者最好的礼物&#xff0c;愿我们共同学习&#xff0c;一起进步

如果对作者发布的内容感兴趣&#xff0c;可点击下方关注公众号 钰娘娘知识汇总 查看更多作者文章哦&#xff01;



推荐阅读
  • SpringBoot简单日志配置
     在生产环境中,只打印error级别的错误,在测试环境中,可以调成debugapplication.properties文件##默认使用logbacklogging.level.r ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 本文记录了在vue cli 3.x中移除console的一些采坑经验,通过使用uglifyjs-webpack-plugin插件,在vue.config.js中进行相关配置,包括设置minimizer、UglifyJsPlugin和compress等参数,最终成功移除了console。同时,还包括了一些可能出现的报错情况和解决方法。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • 使用eclipse创建一个Java项目的步骤
    本文介绍了使用eclipse创建一个Java项目的步骤,包括启动eclipse、选择New Project命令、在对话框中输入项目名称等。同时还介绍了Java Settings对话框中的一些选项,以及如何修改Java程序的输出目录。 ... [详细]
  • DSP中cmd文件的命令文件组成及其作用
    本文介绍了DSP中cmd文件的命令文件的组成和作用,包括链接器配置文件的存放链接器配置信息、命令文件的组成、MEMORY和SECTIONS两个伪指令的使用、CMD分配ROM和RAM空间的目的以及MEMORY指定芯片的ROM和RAM大小和划分区间的方法。同时强调了根据不同芯片进行修改的必要性,以适应不同芯片的存储用户程序的需求。 ... [详细]
  • 本文详细介绍了Android中的坐标系以及与View相关的方法。首先介绍了Android坐标系和视图坐标系的概念,并通过图示进行了解释。接着提到了View的大小可以超过手机屏幕,并且只有在手机屏幕内才能看到。最后,作者表示将在后续文章中继续探讨与View相关的内容。 ... [详细]
  • 深入理解Java虚拟机的并发编程与性能优化
    本文主要介绍了Java内存模型与线程的相关概念,探讨了并发编程在服务端应用中的重要性。同时,介绍了Java语言和虚拟机提供的工具,帮助开发人员处理并发方面的问题,提高程序的并发能力和性能优化。文章指出,充分利用计算机处理器的能力和协调线程之间的并发操作是提高服务端程序性能的关键。 ... [详细]
author-avatar
海容天色2602905655
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有