Klasse Optimierung

Generic1

Top Contributor
Hallo,

ich habe jetzt eine Klasse geschrieben, welche aus der Konsole einen Pin einließt, der Pin hat immer 6 Stellen.
Wenn man zwischen 2 Pineingaben länger als 5s wartet, wird der Buffer sb gelöscht.

Meine Frage wäre jetzt ob wer Fehler bzw. Optimierungen sieht (außer das ich statt den chars 0-9 auch default nehmen könnte)

Java:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class Main {

    KeyThread kt;

    public Main() throws IOException {
        kt = new KeyThread();
        kt.setState(false);
        kt.setWait(5000);
        kt.start();

        final InputStreamReader isr = new InputStreamReader(System.in);
        final BufferedReader br = new BufferedReader(isr);
        String s = "";
        while((s = br.readLine()) != null) {
            handlePinpadKey(s.charAt(0));
            }
        }

    Thread th = null;
    final StringBuffer sb = new StringBuffer();
    private void handlePinpadKey(final char key) {
        switch(key) {
            case 'c':
            case 'e':
                kt.setState(true);
                sb.delete(0, sb.length());
                break;
            case '0':
            case '1':
            case '2':
            case '3':
            case '4':
            case '5':
            case '6':
            case '7':
            case '8':
            case '9':
                kt.setState(false);
                if(sb.length() < 5) {
                    sb.append(key);
                    kt.setState(true);
                    kt.setWait(5000);
                    }
                else {
                    sb.append(key);
                    System.out.println("Pin else: " + sb);
                    sb.delete(0, sb.length());
                    }
                break;
            default:
                System.out.println(key + " nicht gültig");
            }
        }

    private void deleteKeys() {
        sb.delete(0, sb.length());
        System.out.println("Keys wurden gelöscht");
        }

    private final class KeyThread extends Thread {

        private boolean state;
        private long wait;

        public KeyThread() {}

        @Override
        public void run() {
            while(true) {
                if(state && wait < System.currentTimeMillis()) {
                    state = false;
                    deleteKeys();
                    }
                try {
                    Thread.sleep(1000);
                    }
                catch (InterruptedException ex) {
                    System.out.println("asdfd");
                    }
                }
            }
        
        public void setState(final boolean state) {
            this.state = state;
            }
        
        public void setWait(final int wait) {
            this.wait = System.currentTimeMillis() + wait;
            }
        }

    public static void main(String[] args) throws IOException {
        new Main();
        }
}
 

Camill

Bekanntes Mitglied
[JAVA=9] public Main() throws IOException {[/code]
[JAVA=82] System.out.println("asdfd");[/code]
[JAVA=96] public static void main(String[] args) throws IOException {[/code]

Das kann man sicherlich noch verbessern ;)
 
M

Marcinek

Gast
Ich starte das Program und weiß nicht, was ich machen soll.

Dann will ich es beenden und weiß auch nicht wie das geht.

Und
Code:
Exception in thread "main" java.lang.StringIndexOutOfBoundsException: String index out of range: 0
	at java.lang.String.charAt(Unknown Source)
	at Main.<init>(Main.java:19)
	at Main.main(Main.java:97)

Gruß,

Martin
 

Generic1

Top Contributor
So Verbesserung, Vielleicht kann der eine oder andere nochmal drüberschaun ob man nicht noch was optimieren/kompakter machen könnte.
lg

Java:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public final class Main {

    private static final int WAITFOR_KEY;
    private final StringBuffer sb;
    private KeyThread kt;

    static {
        WAITFOR_KEY = 5000;
        }

    public Main() throws IOException {
        sb = new StringBuffer();
        handleKeys();
        }

    private void handleKeys() throws IOException {
        kt = new KeyThread();
        kt.setState(false, 0);
        kt.start();

        System.out.println("Nacheinander Keys eingeben und Enter drücken. Mit \"Ende\" programm beenden. \nWenn zwischen 2 Eingaben eine Zeit länger als 5s vergeht, werden die vorher eingegebenen Keys gelöscht");

        final InputStreamReader isr = new InputStreamReader(System.in);
        final BufferedReader br = new BufferedReader(isr);
        String s = "";
        while((s = br.readLine()) != null) {
            if(s.equalsIgnoreCase("Ende"))
                System.exit(0);
            handlePinpadKey(s.charAt(0));
            }
        }

    private void handlePinpadKey(final char key) {
        switch(key) {
            case 'c':
            case 'e':
                kt.setState(true, WAITFOR_KEY);
                sb.delete(0, sb.length());
                break;
            case '0':
            case '1':
            case '2':
            case '3':
            case '4':
            case '5':
            case '6':
            case '7':
            case '8':
            case '9':
                kt.setState(false, 0);
                if(sb.length() < 5) {
                    sb.append(key);
                    kt.setState(true, WAITFOR_KEY);
                    }
                else {
                    sb.append(key);
                    System.out.println("Pin else: " + sb);
                    sb.delete(0, sb.length());
                    }
                break;
            default:
                System.out.println(key + " nicht gültig");
            }
        }

    private void deleteKeys() {
        System.out.println("Keys " + sb + " gelöscht");
        sb.delete(0, sb.length());
        }

    private final class KeyThread extends Thread {

        private boolean state;
        private long wait;

        public KeyThread() {}

        @Override
        public void run() {
            while(true) {
                if(state && wait < System.currentTimeMillis()) {
                    state = false;
                    deleteKeys();
                    }
                try {
                    Thread.sleep(800);
                    }
                catch (InterruptedException ex) {
                    System.out.println("Exception in class KeyThread in run: " + ex);
                    }
                }
            }
        
        public void setState(final boolean state, final int wait) {
            this.state = state;
            this.wait = System.currentTimeMillis() + wait;
            }
        }

    public static void main(String[] args) throws IOException {
        new Main();
        }
}
 

xehpuk

Top Contributor
Auf
Code:
state
und
Code:
wait
wird von mehr als einem Thread zugegriffen, es gibt aber weder Synchronisierung, noch sind sie
Code:
volatile
.
Warum wartet der KeyThread immer 800 ms?
 

Generic1

Top Contributor
die 800ms sind dazu da dass ich nicht die ganze CPU für die Endlosschleife verbrate, Es reicht wenn es ca. 5s sind (also im schlechtesten Fall 5,8s)

Wie würdest du das mit dem wait und synchronized machen?
lg
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
torresbig Klasse mit extends Calendar über Methoden ändern (Hirnblockade) Allgemeine Java-Themen 7
A Zweite Service Klasse beim Kompilieren Allgemeine Java-Themen 6
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
Atten007 Java-Klasse auf macOS entpacken? Allgemeine Java-Themen 2
M Klasse durch Klassen Aufteilung verbessern, aber wo? Allgemeine Java-Themen 1
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Kombination Interface und Abstrakte Klasse bei Generics Allgemeine Java-Themen 3
EinNickname9 Best Practice Singleton und Singleton mit Instanz zu anderer Klasse -Pattern Allgemeine Java-Themen 30
Y ImagePanel von anderer Klasse in eine MainFrame Klasse hinzufügen. Allgemeine Java-Themen 1
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
missy72 Klassen Eigene Klasse MessageWindow ähnlich der Alert Klasse Allgemeine Java-Themen 2
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
kanywayne Java programmieren: Polynom Klasse Allgemeine Java-Themen 4
L Die abzuleitende Klasse als Parameter übergeben Allgemeine Java-Themen 4
S Klassen Einfügen von unbekannter menge an Variablen in eine Klasse mithilfe von ASM Allgemeine Java-Themen 5
C Klasse mit Mockito simulieren Allgemeine Java-Themen 9
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Wenn eine Klasse zwei Interfaces mit derselben Methodensignatur implementiert: welche wird aufgerufen? Allgemeine Java-Themen 15
Thallius Key/Value Table in Klasse einlesen Allgemeine Java-Themen 14
S static in Interface und Klasse Allgemeine Java-Themen 2
W Was genau sind IOTools? Kann ich stattdessen nicht die Scanner Klasse verwenden? Allgemeine Java-Themen 3
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
X Collections Gibt es eine Klasse welche die Vorteile von List und HashMap vereint, aber konstante Laufzeit (O(1)) hat in Java? Allgemeine Java-Themen 4
D javassist API Klasse in MethodCall ermitteln Allgemeine Java-Themen 8
kodela Klasse mit "gezipten" Daten Allgemeine Java-Themen 6
J Builder Klasse mit Lombok bauen Allgemeine Java-Themen 2
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
M [SOAP] - Klasse aus WSDL ausschließen Allgemeine Java-Themen 2
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
X Klassen Klasse BreakIterator Allgemeine Java-Themen 6
R Arraylist in andere Klasse leiten und bearbeiten Allgemeine Java-Themen 10
kodela Klassen Klasse "vergisst" ihre Daten Allgemeine Java-Themen 2
pkm Kann eine ServerSocket-Klasse nicht stateful sein? Allgemeine Java-Themen 4
E Socket Dynamische Klasse von ObjectOutputStream lesen. Allgemeine Java-Themen 8
M Matcher-Klasse findet match nicht Allgemeine Java-Themen 6
cool_brivk24 Variablen abfragen von Boolean von anderer Klasse Allgemeine Java-Themen 12
S Seltsames Ergebnis mit Date-Klasse Allgemeine Java-Themen 6
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
Neoline Klassen Singleton Klasse buchmanager Allgemeine Java-Themen 19
M Kapselung Modellierung von Intervallen: Klasse Interval Allgemeine Java-Themen 4
B Übernommene Variablen(werte) aus der Main-Klasse ändern? Allgemeine Java-Themen 9
ReinerCoder Klasse kann nicht public deklariert werden Allgemeine Java-Themen 2
ReinerCoder Methode einer Klasse meldet Fehler "misplaced construct(s)" Allgemeine Java-Themen 13
I Collection - contains-Methode überschreiben (anonyme innere Klasse) Allgemeine Java-Themen 4
X Klassen File-Klasse wird als Directory markiert Allgemeine Java-Themen 8
S Methoden Liste soll Methode aus innerer Klasse aufrufen Allgemeine Java-Themen 4
J IndexOutOfBoundsException bei der Nutzung der Klasse Message von mime4j Allgemeine Java-Themen 5
P Array einer abstrakten Klasse Allgemeine Java-Themen 4
J Zugriff auf erstellte Objekte einer Klasse von einer Klasse ausserhalb Allgemeine Java-Themen 3
kodela Dynamisches Array in einer Klasse Allgemeine Java-Themen 5
M Was geschieht mit Java-Klasse, die aus ArrayList entfernt wird? Allgemeine Java-Themen 10
perlenfischer1984 Lombok Builder soll andere Klasse bauen Allgemeine Java-Themen 4
perlenfischer1984 Mit Lombok Builder Felder in Super Klasse füllen Allgemeine Java-Themen 12
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
K Best Practice Auf die Klasse zugreifen im erzeugten ActionListener Allgemeine Java-Themen 2
K Mit Button neue Klasse öffnen Allgemeine Java-Themen 9
J Reflection mit Klasse und Subklasse Allgemeine Java-Themen 11
C Classpath Neue Klasse über einen Button ausführen Allgemeine Java-Themen 3
magdaStone Logikproblem Umschalten von booleans in anderer Klasse Allgemeine Java-Themen 7
P mehrer Verschiedene Objekte in einer Klasse erstellen. Allgemeine Java-Themen 4
A Java Klasse auf Tomcat während der Laufzeit austauschen Allgemeine Java-Themen 1
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
Messoras Klassen Sämtliche Variablen einer Klasse übernehmen Allgemeine Java-Themen 6
H Methoden Methode 'updateItem' der Klasse 'TreeCell' Allgemeine Java-Themen 3
B Animierte Klasse schreiben - Wie? Allgemeine Java-Themen 9
M Klassen Eine Klasse in mehreren Klassen einbinden Allgemeine Java-Themen 11
N Methoden Methoden einer Klasse auf Grundlage eines Strings aufrufen Allgemeine Java-Themen 6
AssELAss Log4j Logging Ausgabe für jede Klasse in seperates File Allgemeine Java-Themen 2
L Eclipse JavaFX Klasse starten programmatisch Allgemeine Java-Themen 1
F Try/catch über ganze Klasse Allgemeine Java-Themen 9
L Von ArrayList abgeleitete Klasse nur mit bestimmten Objekten füllen Allgemeine Java-Themen 1
so_ein_Komischer Erste Schritte java Math Klasse finden? Allgemeine Java-Themen 2
J beans.instantiate(): Klasse kann nicht instanziiert werden Allgemeine Java-Themen 2
I Interface Interface / Klasse - wieso Abstract? Allgemeine Java-Themen 13
R Abstrakte Basisklasse und instanzierte Objekte der abgeleiteten Klasse als Basisklasse übergeben Allgemeine Java-Themen 2
F Methodenaufruf mit abgeleiteter Klasse als Arg... Allgemeine Java-Themen 10
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
A Best Practice Unterschied zwischen einer sauberen Dependency Injection und einer statischen Klasse Allgemeine Java-Themen 5
F Methoden in der Enumeration Klasse Allgemeine Java-Themen 1
S Die Initialisierung von Feldern in ableitender Klasse erzwingen..? Allgemeine Java-Themen 16
S Mit Generics Klasse erstellen die selbst T erweitert..? Allgemeine Java-Themen 4
M Variable außerhalb Klasse definierbar? Allgemeine Java-Themen 2
F Abstrakte Klasse in "For each" Schleife Allgemeine Java-Themen 1
F Enums als innere Klasse sinnvoll? Allgemeine Java-Themen 3
C Klassen Problem mit Funktion einer Generischen Klasse die ein Interface implementiert Allgemeine Java-Themen 0
K Problem: Java-Klasse mit mehreren Threads als eigenen Prozess starten Allgemeine Java-Themen 3
N Automatisches einfügen einer selbst generierten ID in Klasse mit Annotation Allgemeine Java-Themen 8
F Klassen Klasse bei Button klick öffnen Allgemeine Java-Themen 11
F OOP Datenbank-Klasse überall verfübar Allgemeine Java-Themen 2
E KeyCode in anderer Klasse speichern Allgemeine Java-Themen 2
B Klassen Eigene Klasse als Array benutzen Allgemeine Java-Themen 3
M File IO Klasse ... wie einbinden Allgemeine Java-Themen 6
M XML DOM Klasse die Iterable Implementiert Allgemeine Java-Themen 1
P Name der Parent Klasse abfragen Allgemeine Java-Themen 8
D Arraylist eigener Klasse an iReport übergeben Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben