Olá pessoal.
Tenho uma aplicação com 8 gráficos com dados sendo inseridos dinamicamente em um loop infinito. O problema é que o consumo de memória vai aumentando até dar um erro de falta de memória. Abaixo tem um exemplo simples do código de gráfico dinâmico do próprio JFreeChart com o problema de consumo.
Como vcs podem ver, eu configurei series.removeAgedItems(true) e estou invocando o garbage collector a cada 500 passos. Apesar disso, o problema persiste.
Alguma dica?
Obrigado.
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.PrintStream;
import javax.swing.*;
import org.jfree.chart.*;
import org.jfree.chart.axis.ValueAxis;
import org.jfree.chart.plot.XYPlot;
import org.jfree.data.time.*;
import org.jfree.data.xy.XYDataset;
import org.jfree.ui.ApplicationFrame;
import org.jfree.ui.RefineryUtilities;
public class DynamicDataDemo1 extends ApplicationFrame
{
static class DemoPanel extends JPanel
implements ActionListener
{
private TimeSeries series;
private double lastValue;
private JFreeChart createChart(XYDataset xydataset)
{
JFreeChart jfreechart = ChartFactory.createTimeSeriesChart("Dynamic Data Demo", "Time", "Value", xydataset, true, true, false);
XYPlot xyplot = jfreechart.getXYPlot();
ValueAxis valueaxis = xyplot.getDomainAxis();
valueaxis.setAutoRange(true);
valueaxis.setFixedAutoRange(30000D); // in milliseconds
valueaxis = xyplot.getRangeAxis();
valueaxis.setRange(0.0D, 200D);
return jfreechart;
}
public void actionPerformed(ActionEvent actionevent)
{
}
public DemoPanel()
{
super(new BorderLayout());
lastValue = 100D;
series = new TimeSeries("Random Data", Millisecond.class);
TimeSeriesCollection timeseriescollection = new TimeSeriesCollection(series);
ChartPanel chartpanel = new ChartPanel(createChart(timeseriescollection), false);
chartpanel.setPreferredSize(new Dimension(500, 270));
JPanel jpanel = new JPanel();
jpanel.setBorder(BorderFactory.createEmptyBorder(4, 4, 4, 4));
add(chartpanel);
add(jpanel, "South");
}
public void start () {
int count=0;
double d;
Millisecond millisecond;
series.removeAgedItems(true);
do {
d = 0.90000000000000002D + 0.20000000000000001D * Math.random();
lastValue = lastValue * d;
millisecond = new Millisecond();
//System.out.println("Now = " + millisecond.toString());
series.add(new Millisecond(), lastValue);
count++;
if (count > 500) {
System.out.println("CLEANNING MEMORY!!!!!!!");
System.gc();
System.runFinalization();
System.out.println("DONE!!!!!!!");
count = 0;
}
try {
Thread.sleep(10);
} catch (Exception e) {}
} while (lastValue > 0);
}
}
static Class class$org$jfree$data$time$Millisecond; /* synthetic field */
private DemoPanel demopanel;
public DynamicDataDemo1(String s)
{
super(s);
//DemoPanel
demopanel = new DemoPanel();
setContentPane(demopanel);
}
public void start (){
demopanel.start();
}
public static JPanel createDemoPanel()
{
return new DemoPanel();
}
public static void main(String args[])
{
DynamicDataDemo1 dynamicdatademo1 = new DynamicDataDemo1("Dynamic Data Demo");
dynamicdatademo1.pack();
RefineryUtilities.centerFrameOnScreen(dynamicdatademo1);
dynamicdatademo1.setVisible(true);
dynamicdatademo1.start();
}
}
