抽象表模型getValueAt性能

抽象表模型getValueAt性能,第1张

抽象表模型getValueAt性能

有1000个学生(行)和4个字段(列),我们将运行此开关4000次。

前提是错误的,但是您应该进行概要验证。

JTable
使用
flyweight模式

进行单元渲染,因此仅检查
_可见_单元。这个简化的示例说明了基本机制。这个相关的示例可以]很好地扩展到数千行。

如果是Java2D的粉丝;但是为了在Swing组件和布局中最大程度地利用HTML,我建议您使用@camickr建议的组件方法。如果必要的话,可以使用轻量级渲染方法中所看到的JTable,等人,其中单个组件重复用于绘制。下面的示例是该技术的非常简化的概述,仅更改了颜色和位置。

附录:更新示例;另请参阅CellRendererPane并让您的应用程序飞起来:实施Flyweight以提高性能。

import java.awt.Color;import java.awt.Dimension;import java.awt.EventQueue;import java.awt.Graphics;import javax.swing.CellRendererPane;import javax.swing.Jframe;import javax.swing.JLabel;import javax.swing.JPanel;public class PaintComponentTest extends JPanel {    private static final int N = 8;    private static final String s = "<html><big><u>Hello</u></html>";    private JLabel renderer = new JLabel(s);    private CellRendererPane crp = new CellRendererPane();    private Dimension dim;    public PaintComponentTest() {        this.setBackground(Color.black);        dim = renderer.getPreferredSize();        this.add(crp);    }    @Override    protected void paintComponent(Graphics g) {        super.paintComponent(g);        for (int i = 0; i < N; i++) { renderer.setForeground(Color.getHSBColor((float) i / N, 1, 1)); crp.paintComponent(g, renderer, this,     i * dim.width, i * dim.height, dim.width, dim.height);        }    }    private void display() {        Jframe f = new Jframe("PaintComponentTest");        f.setDefaultCloseOperation(Jframe.EXIT_ON_CLOSE);        f.add(this);        f.pack();        f.setSize(dim.width * N, dim.height * (N + 1));        f.setLocationRelativeTo(null);        f.setVisible(true);    }    public static void main(String[] args) {        EventQueue.invokeLater(new Runnable() { @Override public void run() {     new PaintComponentTest().display(); }        });    }}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5105443.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-17

发表评论

登录后才能评论

评论列表(0条)

保存