Programm sehr langsam. Windows 7?

F

FaceToFace

Gast
Grüß Gott.
Ich habe hier im Forum ein Programm gefunden, dass ein Fenster nachzeichnet, dafür aber immer nur die Farbe von einem Pixel ermittelt und diese dann überträgt. Nun habe ich aber ein sehr seltsames Problem: Das Programm läuft unter Windows 7(64-bit), bzw Vista(32-bit) extrem langsam. Es benötig für jede Zeile zu je 30 Pixeln ca 5 sec. Dies ist wirklich sehr lang, da ich für 300 Zeilen dann sehr lang brauche. Bei einem anderen PC ist das aber nicht so: Er hat Windows XP(32-Bit) und einen Pentium 4 mit 3,00 GHz. Er benötigt für das ganze Bild(diesmal 300*400) nur 20 Sekunden. Der andere Computer hat aber einen Core i5 und der sollte rein theoretisch schneller als ein P4 sein o_O. Also meine frage: Liegt es nun am Betriebssystem, oder an meiner Java-Version(sollte die neueste sein)?. Kann mir das echt nicht erklären.

Hier aber erstmal das Programm. Es funktioniert nur am Anfang dauert es auch ein bisschen. Wäre auch nett wenn ihr es probieren könntet und vll Betriebssystem + Zeit(muss nicht fürs ganze Bild sein) angeben könntet:

Java:
import java.awt.*;
/**
 * Beschreiben Sie hier die Klasse Test.
 *
 * @author (Ihr Name)
 * @version (eine Versionsnummer oder ein Datum)
 */
class CrappyDrawTest extends Frame
{
 public static void main(String[] args)
    {
        CrappyDrawTest t = new CrappyDrawTest();
    }
 
    CrappyDrawTest()
            {
 
            super("Kleiner Screen");
            setLayout(new FlowLayout());
            setSize(500,400);
            setLocation(200,100);
            getMinimumSize();
            this.show();
           }
 
   public void paint(Graphics g)
   {
        int x = 1, y = 1;
        while(y <= 400)
        {
            try
            {
                //Ermitteln der Pixelfarbe
                Robot rob = new Robot();
                Color clr = rob.getPixelColor(x, y);
                System.out.println(y +" " + x + clr);
                g.setColor(clr);
            }
            catch(Exception e)
            {
                System.out.println(e);
            }
            //Zeichnen
            g.fillRect(x,y, 1, 1);
            x++;
            if(x > 30)
            {
                y++;
                x=1;
            }
        }
    }
}

mfg Face
 

eRaaaa

Top Contributor
Okay zwei Sachen

a) du erstellst bei jedem Pixel einen neuen Robot...erstelle den einmal und gut ist(das könnte es auch schon gewesen sein, ansonsten muss man mal weiter schauen)
also
Java:
Robot rob=null;
	try {
	    rob = new Robot();
	} catch (AWTException e1) {
	    e1.printStackTrace();
	}
	while (y <= 400) {
//hier dann die Schleife ohne Robot rob = new Robot();
//...
}
/edit: noch besser wahrscheinlich wäre es das ganze nicht in der paint-Methode zu machen?!

b) hat nichts mit dem Problem zu tun, aber this.show() ist deprecated, benutze
Code:
this.setVisible
(true);

c) mal ne andere Frage: wieso benutzt du nicht die Methode createScreenCapture() und packst das BufferedImage in ein JLabel oder so ?!
Java:
public class CrappyDrawTest extends JFrame {
    JLabel label;
    JPanel panel;

    public static void main(String[] args) {
	new CrappyDrawTest();
    }

    CrappyDrawTest() {
	super("Kleiner Screen");
	setLayout(new FlowLayout());
	getMinimumSize();
	label = new JLabel();
	panel = new JPanel();
	add(panel);
	setDefaultCloseOperation(EXIT_ON_CLOSE);
	setLocationRelativeTo(null);
	// Dimension d = Toolkit.getDefaultToolkit().getScreenSize();
	// int x = (int) d.getWidth();
	// int y = (int) d.getHeight();
	paintWindow(400, 200);
	pack();
	setVisible(true);
    }

    private void paintWindow(int x, int y) {
	BufferedImage bi = null;
	try {
	    bi = new Robot().createScreenCapture(new Rectangle(x, y));
	} catch (AWTException e) {
	    e.printStackTrace();
	}
	label.setIcon(new ImageIcon(bi));
	panel.add(label);
    }
}
 
Zuletzt bearbeitet:
F

FaceToFace

Gast
Ich habe den Bot nun umgeändert und es geht nun etwas schneller, aber immer noch kein Vergleich zum anderen Computer. Wie soll ich das ganze nicht in der Paint-Methode machen? Ich weiß es gibt viel einfachere und bessere Methoden, aber ich will nur wissen warum das auf dem XP-Computer viel schneller rennt, als auf dem Windows7/Vista Computer..

mfg
 
G

Gast2

Gast
Habs mal mit laufen lassen:

Windows Vista 32Bit, 2 GB RAM, 1,8GHz Core2Duo - Needed 239304 milliseconds ~ gut 4 Minuten für die 400 Zeilen.
 
F

FaceToFace

Gast
Bei mir dauert es gute 7 Minuten für die 400 Zeilen mit je 30 Pixel... Aber die CPU Auslastung ist aber immer bei 5%...

@eRaaaa:
zu c): Weil ich eig nur die Geschwindigkeit vergleichen will. Und das geht damit im Moment am besten. Und das Ergebnis ist nun, dass es bei einem XP-Computer um 6,5 Minuten schneller geht o_O. Ich denke es liegt an Windows. Ich muss später nämlich Programme schreiben die viel berechnen und auch Zeit brauchen... wie sollen die dann gehen, wenn selbst dieses Programm so langsam läuft?

Gibt es sonst noch andere Programme mit denen ich die Geschwindigkeit berechnen kann(in Java)? Vielleicht ist es ja nur bei diesem einen Programm...

mfg
 

Murray

Top Contributor
Wie lasst ihr das Programm laufen? In Eclipse? Oder von der Kommandozeile aus? Mir scheint nämlich das System.out.println() der limitierende Faktor zu sein (ohne wird es bei mir erheblich schneller) - und das würde sich in einer IDE, die die Konsolenausgaben in irgendeiner Form verarbeitet, möglicherweise anders auswirken als beim Start direkt von der Kommnadozeile aus.
 
F

FaceToFace

Gast
Ich habe das s.o.pln schon weggelöscht, aber so viel unterschied ist da nicht...

Ich führe esmit BlueJ aus oder als Jar Datei.. Beide das selbe Ergebnis...

mfg
 

Murray

Top Contributor
Mach dir doch mal 'ne Ausgabe in die paint Methode:
Java:
public void paint(Graphics g)
   {
   	
   	long t0 = System.currentTimeMillis();
          /* jetzt der ganze Rest */
        System.out.println( "paint finished in " + (System.currentTimeMillis()-t0) + "ms");
   }
Was passiert? Ist die paint-Methode so langsam, oder wird sie sehr oft aufgerufen?
 

Murray

Top Contributor
Seltsam - bei mir (Win XP, Pentium M 2GHz, Anwendung von der Kommandozeile aus gestartet) läuft die paint-Methode mit SysOuts in ca 7Sek, ohne SysOuts in etwa 250ms und mit Wiederverwendung des Robots in 60-150ms
 
F

FaceToFace

Gast
Hmm. Komisch....
Bei mr dauert jeder Pixel 31(!) Millisekunden.
Habe das Programm jetzt so umgeschriebe, das es einem die Millisekunden die das Programm für das Pixel gebraucht hat, ausgibt.
Java:
import java.awt.*;
/**
 * Beschreiben Sie hier die Klasse Test.
 *
 * @author (Ihr Name)
 * @version (eine Versionsnummer oder ein Datum)
 */
class CrappyDrawTest extends Frame
{
 public static void main(String[] args)
    {
        CrappyDrawTest t = new CrappyDrawTest();
    }
 
    CrappyDrawTest()
            {
 
            super("Kleiner Screen");
            setLayout(new FlowLayout());
            setSize(200,400);
            setLocation(200,100);
            getMinimumSize();
            this.setVisible(true);
           }
 
   public void paint(Graphics g)
   {
       long t0 = System.currentTimeMillis();
       try
        {
            //Ermitteln der Pixelfarbe
            Robot rob = new Robot();                
        }
        catch(Exception e)
        {
            System.out.println(e);
        }
        int x = 1, y = 15;
        while(y <= 400)
        {
            long te = System.currentTimeMillis();
            try
            {
                //Ermitteln der Pixelfarbe
                Robot rob = new Robot();
                Color clr = rob.getPixelColor(x, y);
                
                g.setColor(clr);
            }
            catch(Exception e)
            {
                System.out.println(e);
            }
            //Zeichnen
            g.fillRect(x,y, 1, 1);
            x++;
            if(x > 30)
            {
                y++;
                x=1;
            }
            long dif = System.currentTimeMillis() - te;
            System.out.println("Dieser Pixel dauerte " + dif + "ms");
        }
        System.out.println( "paint finished in " + (System.currentTimeMillis()-t0) + "ms");
    }
}

Ich denke es liegt wirklich an XP bzw Vista/7...
Können es vielleicht noch mehr testen?

mfg
 

eRaaaa

Top Contributor
Also du hast ja in Zeile 45 immer noch den Robot drin?! (Deine Schleife(n) sieht eig. auch sehr komisch aus :D )

Wie sieht es denn mit diesem relativ schlanken Programm aus? Hast du damit auch Probleme unter Windows Vista & / ?

Java:
import java.awt.AWTException;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Robot;
import java.awt.image.BufferedImage;

import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;

public class CrappyDrawTest {

    public static void main(String[] args) throws AWTException {
	BufferedImage image = new BufferedImage(30, 400,BufferedImage.TYPE_INT_RGB);
	Graphics g = image.getGraphics();
	Robot rob = new Robot();
	long te = System.currentTimeMillis();
	for (int i = 0; i < image.getHeight(); i++) {
	    for (int j = 0; j < image.getWidth(); j++) {
		g.setColor(rob.getPixelColor(j, i));
		g.fillRect(j, i, 1, 1);
	    }
	}
	System.out.println( "paint finished in " + (System.currentTimeMillis()-te) + " ms");
	JFrame frame = new JFrame();
	JPanel panel = new JPanel();
	panel.add(new JLabel(new ImageIcon(image)));
	frame.add(panel);
	frame.pack();
	frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
	frame.setLocationRelativeTo(null);
	frame.setVisible(true);
    }
}
Läuft bei mir zwischen 200 und 300 ms
 
F

FaceToFace

Gast
WEnn du das Programm meinst, dass du mir geschrieben hast: Ja das funktioniert gut^^

Stimmt den habe ich noch nicht weggelöscht o_O. Aber wenn ich ihn nun wegllösche seht dann: Cannot find variable rob.

Obwohl ich über der Schleife habe:
Java:
try
        {
            //Ermitteln der Pixelfarbe
            Robot rob = new Robot();                
        }
        catch(Exception e)
        {
            System.out.println(e);
        }
Ich verstehs grad nicht??

mfg
 
G

Gast2

Gast
Sieht so aus als ob es an Aero liegt.

Ohne Aero: Needed 1074 milliseconds
Mit Aero: Needed 229102 milliseconds

Ist ja spannend... Ich hab jetzt bei beiden Runs den Code aus dem ersten Posting genommen und nur noch die Zeitmessung in die eingefügt.

Am einfachsten kannst du AERO deaktivieren indem du bei "Designs" -> "Windows klassisch" aussuchst.
 
F

FaceToFace

Gast
Vielen Dank. Ohne Aero geht es vedammt viel schneller.

Aber wen ich die Anwedung weiter send, muss derjenige auch sein Aero deaktivieren und dannausführen... Schlecht gemacht wer auch immer :D

mfg
 

Cola_Colin

Top Contributor
createScreenCapture() geht zuminest mit Windows 7 x64 auch mit Aero im Bruchteil einer Sekunde, das auslesen der Pixel aus dem BufferedImage ist dann sicher schneller als das abfragen der Pixel vom Robot;)
 
M

_Moe_

Gast
Erstmal danke für die Vorarbeit. Ich arbeite gerade auch mit getPixelColor() und hab gestaunt, als ich von meinen Rechnern (zwei mal WinXP) auf die beiden Win7 von nem Kumpel umgestiegen bin und geflucht, wieso das da nicht geht.
Mir dann auf den (schnellen) Lappi Win7 drauf gemacht und er braucht halt echt lange...

Danke auch für die Tips mit den Work-Arounds: Sobald ich zeit hab, mach ich das mit dem Screene.

VG
 
wollte nur auch mal was zu sagen:

also erstmal dauert bei mir ein pixel ca. 15-20mili sek. (Ubuntu, Medion-Netbook 1GB RAM, 2x 1.60GHz)

insgesammt (glaub ich) 1811 (oder 18111?) oder so....:oops:


aber ich find das interessant das die anwendung auf verschiedenen pcs unabhängig von der eigentlichen leißtung unterschiedlich läuft. kann mir das mit meinen sachen auch probieren?
wie kann man das möglichst umgehn?:rtfm:
 

Onkel Hatti

Bekanntes Mitglied
Ich hab das Programm auch ausprobiert und hatte ein bischen darn gespielt, aber auf bessere Werte als 25ms/Punkt kam ich auch nicht.
Gerade in so einem Fall denke ich, man kann das Programm nur mit einem Profiler bearbeiten und sich für langsame Abläufe einen effizienteren Code einfallen lassen.
Ich hab mal nen Datenbank-Programm gemacht und mir für eine Abfrage einen wunderbaren View gestrickt. Der dauerte dann aber in der Abfrage immer 2 s. Auch die SELECT Anweisung direkt dauerte mir zu lange. Es ging dann am schnellsten, indem ich die betroffenen Tabellen einzeln abgefragt habe und sie in meinem Programm selbst zusammengesetzt habe, so das das gewünschte Ergebnis kam.

Hatti
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A "Hello World"-Programm läuft nicht Java Basics - Anfänger-Themen 16
J Delay erzeugen, ohne Programm zu blockieren Java Basics - Anfänger-Themen 7
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
M Java Mail Programm Java Basics - Anfänger-Themen 4
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
M Mini Jar-Programm Java Basics - Anfänger-Themen 51
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
M Das Programm stellt nichts dar Java Basics - Anfänger-Themen 2
K Programm compilierbar aber nicht ausführbar... Java Basics - Anfänger-Themen 21
Z Programm Ideen Java Basics - Anfänger-Themen 8
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
T Programm stürzt ab Java Basics - Anfänger-Themen 40
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
N Programm Funktioniert mit .txt Datei aber nicht mit .rtf Datei Java Basics - Anfänger-Themen 2
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
Jul1n4tor Programm mit Scanner und If-Statements Java Basics - Anfänger-Themen 2
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
K Ist das Programm schlecht bzw. schlampig programmiert ? Java Basics - Anfänger-Themen 9
Zrebna Kann Java Programm nicht in Konsole ausführen Java Basics - Anfänger-Themen 1
K Warum läuft das Programm nicht(bzw. nicht richtig) Java Basics - Anfänger-Themen 4
M Von Eclipse zum richtigen Programm Java Basics - Anfänger-Themen 1
nbergmann IntelliJ: Wie lade ich ein fertiges Programm aus dem Lehrbuch? Java Basics - Anfänger-Themen 26
D Anfängerfrage zu meinem Programm. Java Basics - Anfänger-Themen 15
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 22
I Jetty starten von Programm (Main) Java Basics - Anfänger-Themen 27
Kydo Programm Beschreibung Java Basics - Anfänger-Themen 3
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 7
T Java FXML selbes Fenster verschiedene Stellen im Programm Java Basics - Anfänger-Themen 5
frager2345 Programm erstellen ohne Autoboxing und Unboxing Java Basics - Anfänger-Themen 13
D JAVA Programm schreiben Java Basics - Anfänger-Themen 46
P exportiertes Programm funktioniert nur teilweise Java Basics - Anfänger-Themen 7
J Mein Programm läuft bei der ersten Eingabe nicht mehr weiter, woran liegt das? Java Basics - Anfänger-Themen 6
M Wo hält das Programm an? Java Basics - Anfänger-Themen 11
J Mein Java Programm lässt sich nicht mehr bearbeiten Java Basics - Anfänger-Themen 2
Fugover Programm funktioniert nicht Java Basics - Anfänger-Themen 11
Fugover Kopfrechnen-Programm Java Basics - Anfänger-Themen 6
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
sserio Wieso funktioniert mein Programm nicht Java Basics - Anfänger-Themen 2
sserio Größtes Palindrom-Produkt Programm funktioniert nur halb Java Basics - Anfänger-Themen 23
J selbst erstellte Datei mit Programm öffnen Java Basics - Anfänger-Themen 10
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
A wie kann ich es in meinem Programm rein tun Java Basics - Anfänger-Themen 8
S Fehler beim Programm Java Basics - Anfänger-Themen 2
Jose05 Fehler im Programm feststellen Java Basics - Anfänger-Themen 2
F Kann mir jemand kurz dieses Programm erklären? Java Basics - Anfänger-Themen 22
I Programm erkennt nicht an das Array zurückgegeben wird trotz Initialisierung *einfach* Java Basics - Anfänger-Themen 9
J Nach dem Exportieren funktioniert mein Programm nicht mehr Java Basics - Anfänger-Themen 8
P Mein Programm wird zwar erfolgreich Compiliert, öffnet sich aber nicht Java Basics - Anfänger-Themen 6
J Kann ich mein Programm so schreiben? Java Basics - Anfänger-Themen 4
A Lotto Programm Java Basics - Anfänger-Themen 3
S Programm erstellen Java Basics - Anfänger-Themen 3
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
S MinMax Programm erstellen Java Basics - Anfänger-Themen 4
J Interpreter-Fehler Programm gibt nicht gewünschtes Ergebnis aus Java Basics - Anfänger-Themen 11
brypa Programm mit Eingabe Java Basics - Anfänger-Themen 129
B Java Programm soll mit Python kommunizeren Java Basics - Anfänger-Themen 1
SpigBin Programm läuft nicht weiter... Java Basics - Anfänger-Themen 10
M JAVA Programm in Website einbinden Java Basics - Anfänger-Themen 19
B Programm, dass alle 3 Tage eine Webseite öffnet? Java Basics - Anfänger-Themen 20
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
N Eclipse Programm normal ausführen Java Basics - Anfänger-Themen 1
D Programm auf Enter warten lassen Java Basics - Anfänger-Themen 2
C Programm das feststellen kann, ob eine eingegebene Zahl einem Schaltjahr entspricht, richtig geschrieben? Java Basics - Anfänger-Themen 11
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
WAB9703-04 Programm zum automatischen Ausfüllen von Formularen programmieren Java Basics - Anfänger-Themen 3
OSchriever Jar-Programm läuft auf Windows aber nicht auf Linux(Raspberri Pi4) Java Basics - Anfänger-Themen 22
G Programm Code Java Basics - Anfänger-Themen 5
CptK Achsenskalierung in Koordinatensystem hängt Programm auf Java Basics - Anfänger-Themen 5
H Kann eine while-Schleife ein Programm blockieren? Java Basics - Anfänger-Themen 8
TimoN11 Mail Programm mit Java? Java Basics - Anfänger-Themen 1
Sajeel Chattha Dieses Programm umschreiben Java Basics - Anfänger-Themen 5
J Programm beenden ohne System.exit() oder Runtime.exit() Java Basics - Anfänger-Themen 5
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
A Programm Histogram Java Basics - Anfänger-Themen 2
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
CT9288 Interaktion mit laufendem Programm -Fachbegriffe Java Basics - Anfänger-Themen 2
Gaudimagspam Assertions im Programm hinzufügen Java Basics - Anfänger-Themen 4
G Weiß jemand wie man dieses Programm schreibt? Java Basics - Anfänger-Themen 84
C Programm ausführen ohne JRE? Java Basics - Anfänger-Themen 3
justemii Gehalt berechnen - Aufgabe Java-Programm Java Basics - Anfänger-Themen 9
N Best Practice How can I creat a programm with java under windows 10 in order to open an spreadsheet in libreoffice calc format Java Basics - Anfänger-Themen 11
W Programm dass Palindrome erkennt Java Basics - Anfänger-Themen 6
K Erste Schritte Programm geht aus Schleife, warum? Java Basics - Anfänger-Themen 2
P Wie für EIN Java Programm von 64bit Java (=Standard) auf 32bit Java Installation (Windows) umschalten? Java Basics - Anfänger-Themen 6
K Programm stoppt einfach ohne Grund Java Basics - Anfänger-Themen 4
M Rekursives Programm zum Anzeigen von Primzahlen Java Basics - Anfänger-Themen 3
X Kurzes Java-Programm, das sich komisch verhält Java Basics - Anfänger-Themen 6
Zrebna Programm kann aus der Konsole nicht gestartet werden (in der IDE läuft es) Java Basics - Anfänger-Themen 2
K Error bei meinem Programm - Hilfe Java Basics - Anfänger-Themen 8
J Programm schreiben Java Basics - Anfänger-Themen 5
T Kann jemand kurz das Programm testen? Java Basics - Anfänger-Themen 13
T Programm Schleife/if Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben