JAVA笔记 Form界面的log展示
import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class MainForm extends Thread{
private JFrame frame;
private JScrollPane scrollpanel;
private JPanel panel = new JPanel();
private final JTextArea text;
private boolean islogging=true;
Log log =LogFactory.getLog(MainForm.class);
public MainForm(){
final JButton startButton = new JButton("start");
startButton.setActionCommand("start");
final JButton stopButton = new JButton("stop");
stopButton.setActionCommand("stop");
text= new JTextArea();
scrollpanel = new JScrollPane();
scrollpanel.setViewportView(text);
panel.setLayout(new BorderLayout());
panel.add(scrollpanel,BorderLayout.CENTER);
JPanel bottom = new JPanel();
bottom.setLayout(new FlowLayout());
bottom.add(startButton);
bottom.add(stopButton);
panel.add(bottom,BorderLayout.SOUTH);
ActionListener listener = new ActionListener(){
@Override
public void actionPerformed(ActionEvent e) {
if("start".equals(e.getActionCommand())){
Thread thread = new Thread(){
public void run(){
//你自己的操作
}
};
thread.start();
}
else if("stop".equals(e.getActionCommand())){
//你自己的操作
}
else{
}
}
};
startButton.addActionListener(listener);
stopButton.addActionListener(listener);
frame = new JFrame();
frame.setTitle("程序");
frame.getContentPane().add(panel);
frame.setSize(600,400);
frame.setResizable(false);
frame.setVisible(true);
frame.addWindowListener(new WindowListener(){
@Override
public void windowActivated(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowClosed(WindowEvent e) {
System.exit(0);
}
@Override
public void windowClosing(WindowEvent e) {
islogging=false;
System.exit(0);
}
@Override
public void windowDeactivated(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowDeiconified(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowIconified(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowOpened(WindowEvent e) {
// TODO Auto-generated method stub
}
});
@Override
public void run() {
int count=0;
while(islogging){
try{
synchronized(this.text){
//从log队列中取出下一个
LogBean msg =LogDispacher.push();
if(msg==null){
continue;
}
LogBean.LogType type=msg.getType();
//判断日志是否要显示到界面上
if(type==LogBean.LogType.LOGFILE||type==LogBean.LogType.BOTH){
log.info(msg.getMsg());
if(msg.getType()==LogBean.LogType.LOGFILE){
continue;
}
}
count++;
if(count>100){
count=0;
this.text.setText("");
}
StringBuilder build = new StringBuilder(this.text.getText());
build.append(msg.getMsg());
this.text.setText(build.toString()+"\n");
}
}
catch(Exception ex){
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
package com.ect.smsmessager.server;
import java.util.LinkedList;
import java.util.Queue;
import com.ect.smsmessager.bean.LogBean;
public class LogDispacher {
public static Queue<LogBean> logQueue= new LinkedList<LogBean>();
public static void poll(String msg,LogBean.LogType type){
LogBean bean = new LogBean(msg,type);
synchronized(logQueue){
logQueue.offer(bean);
}
}
public static LogBean push(){
synchronized(logQueue){
if(logQueue!=null&&!logQueue.isEmpty()){
return logQueue.poll();
}
return null;
}
}
}
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
public class MainForm extends Thread{
private JFrame frame;
private JScrollPane scrollpanel;
private JPanel panel = new JPanel();
private final JTextArea text;
private boolean islogging=true;
Log log =LogFactory.getLog(MainForm.class);
public MainForm(){
final JButton startButton = new JButton("start");
startButton.setActionCommand("start");
final JButton stopButton = new JButton("stop");
stopButton.setActionCommand("stop");
text= new JTextArea();
scrollpanel = new JScrollPane();
scrollpanel.setViewportView(text);
panel.setLayout(new BorderLayout());
panel.add(scrollpanel,BorderLayout.CENTER);
JPanel bottom = new JPanel();
bottom.setLayout(new FlowLayout());
bottom.add(startButton);
bottom.add(stopButton);
panel.add(bottom,BorderLayout.SOUTH);
ActionListener listener = new ActionListener(){
@Override
public void actionPerformed(ActionEvent e) {
if("start".equals(e.getActionCommand())){
Thread thread = new Thread(){
public void run(){
//你自己的操作
}
};
thread.start();
}
else if("stop".equals(e.getActionCommand())){
//你自己的操作
}
else{
}
}
};
startButton.addActionListener(listener);
stopButton.addActionListener(listener);
frame = new JFrame();
frame.setTitle("程序");
frame.getContentPane().add(panel);
frame.setSize(600,400);
frame.setResizable(false);
frame.setVisible(true);
frame.addWindowListener(new WindowListener(){
@Override
public void windowActivated(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowClosed(WindowEvent e) {
System.exit(0);
}
@Override
public void windowClosing(WindowEvent e) {
islogging=false;
System.exit(0);
}
@Override
public void windowDeactivated(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowDeiconified(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowIconified(WindowEvent e) {
// TODO Auto-generated method stub
}
@Override
public void windowOpened(WindowEvent e) {
// TODO Auto-generated method stub
}
});
@Override
public void run() {
int count=0;
while(islogging){
try{
synchronized(this.text){
//从log队列中取出下一个
LogBean msg =LogDispacher.push();
if(msg==null){
continue;
}
LogBean.LogType type=msg.getType();
//判断日志是否要显示到界面上
if(type==LogBean.LogType.LOGFILE||type==LogBean.LogType.BOTH){
log.info(msg.getMsg());
if(msg.getType()==LogBean.LogType.LOGFILE){
continue;
}
}
count++;
if(count>100){
count=0;
this.text.setText("");
}
StringBuilder build = new StringBuilder(this.text.getText());
build.append(msg.getMsg());
this.text.setText(build.toString()+"\n");
}
}
catch(Exception ex){
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
package com.ect.smsmessager.server;
import java.util.LinkedList;
import java.util.Queue;
import com.ect.smsmessager.bean.LogBean;
public class LogDispacher {
public static Queue<LogBean> logQueue= new LinkedList<LogBean>();
public static void poll(String msg,LogBean.LogType type){
LogBean bean = new LogBean(msg,type);
synchronized(logQueue){
logQueue.offer(bean);
}
}
public static LogBean push(){
synchronized(logQueue){
if(logQueue!=null&&!logQueue.isEmpty()){
return logQueue.poll();
}
return null;
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述