Java JTable在GUI中为空,控制台显示填充的DefaultTableModel

Java JTable在GUI中为空,控制台显示填充的DefaultTableModel,java,swing,model-view-controller,user-interface,netbeans,Java,Swing,Model View Controller,User Interface,Netbeans,使用Netbeans GUI builder,是否可能是同步、线程或按值传递/引用问题导致无法将DefaultTableModel从实用程序类传递到JFrame 控制台输出在这两种情况下都是相同的,代码只是从实用程序类复制/粘贴并放置在JFrame中。但是,如果使用了实用程序类,则没有GUI输出 如何追踪JTable为空或空白的原因?据我所知,DefaultTableModel中填充了数据 控制台输出: init: Deleting: /home/thufir/NetBeansProjects/

使用Netbeans GUI builder,是否可能是同步、线程或按值传递/引用问题导致无法将DefaultTableModel从实用程序类传递到JFrame

控制台输出在这两种情况下都是相同的,代码只是从实用程序类复制/粘贴并放置在JFrame中。但是,如果使用了实用程序类,则没有GUI输出

如何追踪JTable为空或空白的原因?据我所知,DefaultTableModel中填充了数据

控制台输出:

init:
Deleting: /home/thufir/NetBeansProjects/SwingNNTP/build/built-jar.properties
deps-jar:
Updating property file: /home/thufir/NetBeansProjects/SwingNNTP/build/built-jar.properties
Compiling 1 source file to /home/thufir/NetBeansProjects/SwingNNTP/build/classes
warning: [options] bootstrap class path not set in conjunction with -source 1.5
1 warning
compile:
run:
Apr 23, 2012 9:46:25 PM net.bounceme.dur.nntp.EnumNNTP <init>
INFO: SingletonNNTP..only once...
Apr 23, 2012 9:46:25 PM net.bounceme.dur.nntp.PropertiesReader getProps
INFO: NNTP.loadMessages...
Apr 23, 2012 9:46:25 PM net.bounceme.dur.nntp.EnumNNTP connect
INFO: SingletonNNTP.connect..
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.EnumNNTP setIndex
INFO: SingletonNNTP.setIndex..164
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.EnumNNTP page
INFO: SingletonNNTP.page..174
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.EnumNNTP setIndex
INFO: SingletonNNTP.setIndex..164
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.EnumNNTP getMessages
INFO: SingletonNNTP.getMessages..
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:26 PM net.bounceme.dur.nntp.MessageBean setFrom
INFO: MessageBean.setFrom..unknown <post@gwene.org>
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:24 PDT 2012The return of the euro crisis: Beyond battlefield medicine
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:24 PDT 2012North Korea’s gulag: Never again?
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:24 PDT 2012Nationalising YPF: Cristina scrapes the barrel
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Charlemagne: April showers on the euro
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Jihadist terrorism: Al-Qaeda is down, but far from out
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Justice for dictators: History rules
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Buttonwood: Feeling peaky
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Couples and housework: The ironing lady
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:23 PDT 2012Markets
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:22 PDT 2012The World Bank: Kim selection
Apr 23, 2012 9:46:27 PM net.bounceme.dur.nntp.MessageUtils getDataTableModel
INFO: unknown <post@gwene.org>Sun Apr 22 02:58:22 PDT 2012The Economist commodity-price index
BUILD SUCCESSFUL (total time: 13 seconds)
init:
删除:/home/thufir/NetBeansProjects/SwingNNTP/build/build-jar.properties
deps jar:
正在更新属性文件:/home/thufir/NetBeansProjects/SwingNNTP/build/build-jar.properties
将1个源文件编译为/home/thufir/NetBeansProjects/SwingNNTP/build/classes
警告:[选项]引导类路径未与-source 1.5一起设置
1警告
汇编:
运行:
2012年4月23日晚上9:46:25 net.bounceme.dur.nntp.enumntp
信息:SingleTonntp..仅一次。。。
2012年4月23日晚上9:46:25 net.bounceme.dur.nntp.PropertiesReader getProps
信息:NNTP.loadMessages。。。
2012年4月23日晚上9:46:25 net.bounceme.dur.nntp.enumntp connect
信息:singletonntp.connect。。
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.enumntp setIndex
信息:singletonntp.setIndex..164
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.enumntp第页
信息:SingleTonntp.第174页
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.enumntp setIndex
信息:singletonntp.setIndex..164
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.enumntp getMessages
信息:singletonntp.getMessages。。
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:26 net.bounceme.dur.nntp.MessageBean setFrom
信息:MessageBean.setFrom..未知
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳2012年4月22日02:58:24 PDT欧元危机的回归:超越战场医学
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳2012年4月22日02:58:24北朝鲜古拉格:再也没有了?
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳4月22日02:58:24 PDT 2012年国家化YPF:克里斯蒂娜刮桶
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳2012年4月22日02:58:23 PDT 2012年夏令营:4月欧元区阵雨
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳4月22日02:58:23 PDT 2012圣战恐怖主义:基地组织倒台了,但还远没有退出
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳4月22日02:58:23 PDT 2012独裁者的正义:历史规则
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳4月22日02:58:23 PDT 2012Buttonwood:感觉巅峰
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳4月22日02:58:23 PDT 2012情侣和家务:熨烫女士
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知Sun Apr 22 02:58:23 PDT 2012市场
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知太阳2012年4月22日02:58:22 PDT世界银行:Kim selection
2012年4月23日晚上9:46:27 net.bounceme.dur.nntp.MessageUtils getDataTableModel
信息:未知Sun Apr 22 02:58:22 PDT 2012经济学人商品价格指数
构建成功(总时间:13秒)
MessagesJFrame中注释掉的代码实际上是有效的,而将其传递给实用程序类会带来问题——一个显然是空的JTable

JFrame:

package net.bounceme.dur.nntp;

import java.util.List;
import java.util.Vector;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.mail.Message;
import javax.swing.table.DefaultTableModel;

public class MessagesJFrame extends javax.swing.JFrame {

    private DefaultTableModel defaultTableModel = new DefaultTableModel();

    public MessagesJFrame() throws Exception {
        initComponents();
        MessageUtils.loadMessages();
        defaultTableModel = MessageUtils.getDataTableModel();
        /*
        EnumNNTP nntp = EnumNNTP.INSTANCE;
        List<Message> listOfMessages = nntp.getMessages(false);//nntp debug off
        Vector messages = new Vector();
        for (Message m : listOfMessages) {
            MessageBean messageBean = new MessageBean(m);
            messages.add(messageBean);
        }
        defaultTableModel.addColumn("from");
        defaultTableModel.addColumn("sent");
        defaultTableModel.addColumn("subject");
        for (Object o : messages) {  //awkward Vector manipulation
            MessageBean messageBean = (MessageBean) o;
            Vector messageBeanAsVector = messageBean.getVector();
            defaultTableModel.addRow(messageBeanAsVector);
        }*/
    }

    /**
     * This method is called from within the constructor to initialize the form.
     * WARNING: Do NOT modify this code. The content of this method is always
     * regenerated by the Form Editor.
     */
    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">
    private void initComponents() {

        jScrollPane1 = new javax.swing.JScrollPane();
        jTable1 = new javax.swing.JTable();

        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);

        jTable1.setModel(defaultTableModel);
        jScrollPane1.setViewportView(jTable1);

        javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
        getContentPane().setLayout(layout);
        layout.setHorizontalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
                .addContainerGap()
                .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 819, Short.MAX_VALUE)
                .addContainerGap())
        );
        layout.setVerticalGroup(
            layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
            .addGroup(layout.createSequentialGroup()
                .addContainerGap()
                .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 455, Short.MAX_VALUE)
                .addContainerGap())
        );

        pack();
    }// </editor-fold>

    /**
     * @param args the command line arguments
     */
    public static void main(String args[]) {
        /*
         * Set the Nimbus look and feel
         */
        //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
        /*
         * If Nimbus (introduced in Java SE 6) is not available, stay with the
         * default look and feel. For details see
         * http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html
         */
        try {
            for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
                if ("Nimbus".equals(info.getName())) {
                    javax.swing.UIManager.setLookAndFeel(info.getClassName());
                    break;
                }
            }
        } catch (ClassNotFoundException ex) {
            java.util.logging.Logger.getLogger(MessagesJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (InstantiationException ex) {
            java.util.logging.Logger.getLogger(MessagesJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (IllegalAccessException ex) {
            java.util.logging.Logger.getLogger(MessagesJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (javax.swing.UnsupportedLookAndFeelException ex) {
            java.util.logging.Logger.getLogger(MessagesJFrame.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        }
        //</editor-fold>

        /*
         * Create and display the form
         */
        java.awt.EventQueue.invokeLater(new Runnable() {

            public void run() {
                try {
                    new MessagesJFrame().setVisible(true);
                } catch (Exception ex) {
                    Logger.getLogger(MessagesJFrame.class.getName()).log(Level.SEVERE, null, ex);
                }
            }
        });
    }
    // Variables declaration - do not modify
    private javax.swing.JScrollPane jScrollPane1;
    private javax.swing.JTable jTable1;
    // End of variables declaration
}
package net.bounceme.dur.nntp;
导入java.util.List;
导入java.util.Vector;
导入java.util.logging.Level;
导入java.util.logging.Logger;
导入javax.mail.Message;
导入javax.swing.table.DefaultTableModel;
公共类MessagesJFrame扩展了javax.swing.JFrame{
私有DefaultTableModel DefaultTableModel=新的DefaultTableModel();
public MessagesJFrame()引发异常{
初始化组件();
MessageUtils.loadMessages();
defaultTableModel=MessageUtils.getDataTableModel();
/*
EnumNNTP nntp=EnumNNTP.INSTANCE;
listOfMessages=nntp.getMessages(false);//nntp调试关闭
向量消息=新向量();
对于(消息m:listOfMessages){
MessageBean MessageBean=新MessageBean(m);
messages.add(messageBean);
}
defaultTableModel.addColumn(“from”);
defaultTableModel.addColumn(“已发送”);
defaultTableModel.addColumn(“主题”);
对于(对象o:messages){//向量操作
MessageBean MessageBean=(MessageBean)o;
Vector messageBeanAsVector=messageBean.getVector();
defaultTableModel.addRow(messageBeanAsVector);
}*/
}
/**
*这种方法
package net.bounceme.dur.nntp;

import java.util.Iterator;
import java.util.List;
import java.util.Vector;
import java.util.logging.Logger;
import javax.mail.Message;
import javax.swing.table.DefaultTableModel;

public class MessageUtils {

    private static final long serialVersionUID = 1L;
    private static final Logger LOG = Logger.getLogger(MessageUtils.class.getName());
    private static DefaultTableModel defaultTableModel = new DefaultTableModel();
    private static EnumNNTP nntp = EnumNNTP.INSTANCE;
    private static Vector messages = new Vector();

    public static void loadMessages() throws Exception {
        List<Message> listOfMessages = nntp.getMessages(false);//nntp debug off
        messages.clear();
        for (Message m : listOfMessages) {
            MessageBean messageBean = new MessageBean(m);
            messages.add(messageBean);
        }
        loadTableModel();
    }

    private static void loadTableModel() {
        defaultTableModel = new DefaultTableModel();
        defaultTableModel.addColumn("from");
        defaultTableModel.addColumn("sent");
        defaultTableModel.addColumn("subject");
        for (Object o : messages) {  //awkward Vector manipulation
            MessageBean messageBean = (MessageBean) o;
            Vector messageBeanAsVector = messageBean.getVector();
            defaultTableModel.addRow(messageBeanAsVector);
        }
    }

    public static DefaultTableModel getDataTableModel() {
        Vector vector = defaultTableModel.getDataVector();
        Iterator it = vector.iterator();
        while (it.hasNext()) {
            Vector v = (Vector) it.next();
            Iterator i = v.iterator();
            StringBuilder row = new StringBuilder();
            while (i.hasNext()) {
                row.append(i.next());
            }
            LOG.info(row.toString());
        }
        return defaultTableModel;
    }

    public static void setDataTableModel(DefaultTableModel dataTableModel) {
        MessageUtils.defaultTableModel = dataTableModel;
    }

    public static Vector getMessages() {
        return messages;
    }

    public static void setMessages(Vector messages) {
        MessageUtils.messages = messages;
    }
}
defaultTableModel = MessageUtils.getDataTableModel();