Zu viel Code?

Status
Nicht offen für weitere Antworten.

Mark110

Bekanntes Mitglied
Ist folgender Code zu groß sollte ich das anders schrieben?
Funktionieren tut er.


Code:
ctChecked = pageEF.getCheckboxCombinationTruck()
						.isChecked();
				if (ct.equals("-1")) {
					if (ctChecked == false) {
						pageEF.getCheckboxCombinationTruck().click();
					}
				} else {
					if (ctChecked == true) {
						pageEF.getCheckboxCombinationTruck().click();
					}
				}
stChecked = pageEF.getCheckboxSemitrailerTruck()
						.isChecked();
				if (st.equals("-1")) {
					if (stChecked == false) {
						pageEF.getCheckboxSemitrailerTruck().click();
					}
				} else {
					if (stChecked == true) {
						pageEF.getCheckboxSmallVehicle().click();
					}
				}

				svChecked = pageEF.getCheckboxSmallVehicle()
						.isChecked();
				if (sv.equals("-1")) {
					if (svChecked == false) {
						pageEF.getCheckboxSmallVehicle().click();
					}
				} else {
					if (svChecked == true) {
						pageEF.getCheckboxSmallVehicle().click();
					}
				}
 
G

Gast

Gast
Besonders schön ist das nicht. Aber wie sagt man immer so schön, wenns läuft und nicht gerade der Kern der Applikation ist, dann passt es schon irgendwie.


Verbesserungsvorschläge:

Was ist den mit den inneren "else" Fällen? Zumindest ein Kommentar wäre nett.

Ich sehe drei analoge Abfrageblöcke, kann man das nicht über ein gemeinsamens Interface und eine entsprechende Methode machen?

equals("-1") was soll den das bitteschön sein? Wenn das schon so komisch sein muss, dann würde ich für das sv, st bzw. ct Objekt eine Methode bereitstellen, die mir true/false zurück gibt. isValid o.ä.

Dann noch ein Klassiker if("xxx == true"), da reicht if(xxx) bei false analog.
 
S

SlaterB

Gast
der Aufbau der drei Abschnitte läßt vermuten, dass in Zeile 20
auch getCheckboxSemitrailerTruck() stehen sollte, und nicht getCheckboxSmallVehicle(),
stimmts?
--------
in jedem Fall sollte die benötigte Checkbox nicht 3x mit pageEF.getCheckboxSmallVehicle() einzeln angesprochen werden,
das provoziert nur Fehler wie den obigen,
-> in einer Variablen speichern, currentCheckBox,

oder:
die drei Abschnitte könnten zu einem zusammengekürzt werde, der in einer Extra-Methode steht und mit drei einfachen Aufrufen a la
checkCheckBox(pageEF.getCheckboxSmallVehicle(), sv);
aufgerufen wird

-------

> if (svChecked == false) {

-> if (!svChecked) {

-------

> if (svChecked == true) {

-> if (svChecked) {

--------

> if (sv.equals("-1")) {
> if (svChecked == false) {
> pageEF.getCheckboxSmallVehicle().click();
> }
> } else {
> if (svChecked == true) {
> pageEF.getCheckboxSmallVehicle().click();
> }
> }

->


if (sv.equals("-1") != svChecked) {
pageEF.getCheckboxSmallVehicle().click();
}
 

Mark110

Bekanntes Mitglied
Danke für die hilreichen Antworten.
Natürlich habt irh recht.. mit meinen IF Abfragen.. ich hatte gedacht es sähe überishclticher aus wenn ich dort == false oder true schreibe.

Das habe ich jetzt mal korrigiert.

Code:
		freightList = new FreightOfferList();

			tl = freightList.getFreightOffersFromDatabase();
			lp.getButtonEnterFreightOffers().click();

			for (FreightOffer fOffer : tl.getFreightOffers()) {
				date = tchelperclass.util.Date.getDatum();

				pageEF.getButtonNew().click();
				pageEF.getFieldOn().setText(date);
				pageEF.getListCountryFrom().click(3);
				pageEF.getListCountryTo().click(3);
				pageEF.getFieldPostalCodeFrom().setText(fOffer.getVonPLZ());
				pageEF.getFieldTownFrom().setText(fOffer.getVonOrt());
				pageEF.getFieldPostalCodeTo().setText(fOffer.getNachPLZ());
				pageEF.getFieldTownTo().setText(fOffer.getNachOrt());
				pageEF.getFieldLenght().setText(fOffer.getLadungLaenge());
				pageEF.getFieldWeight().setText(fOffer.getLadungGewicht());
				pageEF.getFieldLoadingPlaces().setText(fOffer.getBeladen());
				pageEF.getFieldDischarginPlaces().setText(fOffer.getEntladen());
				pageEF.getFieldTypOfGods().setText(fOffer.getLadung_ware());
				pageEF.getFieldPriceOfGoods().setText(fOffer.getLadung_preis());

				ct = fOffer.getLkw_gliederzug();
				st = fOffer.getLkw_sattelzug();
				sv = fOffer.getLkw_klein_fahrz();
				adr = fOffer.getLadung_adr();
				obtp = fOffer.getLkwAlternativAufbau();

				ctChecked = pageEF.getCheckboxCombinationTruck().isChecked();
				if (ct.equals("-1")) {
					if (!(ctChecked)) {
						pageEF.getCheckboxCombinationTruck().click();
					}
				} else {
					if (ctChecked) {
						pageEF.getCheckboxCombinationTruck().click();
					}
				}

				stChecked = pageEF.getCheckboxSemitrailerTruck().isChecked();
				if (st.equals("-1")) {
					if (!(stChecked)) {
						pageEF.getCheckboxSemitrailerTruck().click();
					}
				} else {
					if (stChecked) {
						pageEF.getCheckboxSemitrailerTruck().click();
					}
				}

				svChecked = pageEF.getCheckboxSmallVehicle().isChecked();
				if (sv.equals("-1")) {
					if (!(svChecked)) {
						pageEF.getCheckboxSmallVehicle().click();
					}
				} else {
					if (svChecked) {
						pageEF.getCheckboxSmallVehicle().click();
					}
				}

				adrChecked = pageEF.getCheckboxADR().isChecked();
				if (adr.equals("-1")) {
					if (!(adrChecked)) {
						pageEF.getCheckboxADR().click();
					}
				} else {
					if (adrChecked) {
						pageEF.getCheckboxADR().click();
					}
				}

				otherBodyTypsPossibleChecked = pageEF.getCheckboxOtherBodyTypesPossible().isChecked();
				if (obtp.equals("-1")) {
					if (!(otherBodyTypsPossibleChecked)) {
						pageEF.getCheckboxOtherBodyTypesPossible().click();
					}
				} else {
					if (otherBodyTypsPossibleChecked) {
						pageEF.getCheckboxOtherBodyTypesPossible().click();
					}
				}

				pageEF.getListTypOfBody().click(
						Integer.valueOf(fOffer.getLkwAufbau()).intValue());
				pageEF.getFieldRemarks().setText(fOffer.getBemerkung());
				pageEF.getListContactInYourCompany().click(1);
				pageEF.getFieldInternalRemarks()
						.setText(fOffer.getIBemerkung());
				pageEF.getButtonSave().click();
			}
			pageEF.getButtonExit().click();

Mein Vorteil ist, wenn ich die checkbox dreimal neu mit pageEF.getCheckboxSmallVehicle() angesprochen wird, dass ich bei einem Typ Wechsel in der klasse die mir die pageEF erzeugt in der klasse nichts mehr ändern muss.
 
S

SlaterB

Gast
> Mein Vorteil ist, wenn ich die checkbox dreimal neu mit pageEF.getCheckboxSmallVehicle() angesprochen wird [..]
verstehe ich nicht,

jedenfalls war das == true noch einer der kleinsten Tipps,
die anderen beiden
- drei ifs zu einem zusammenfassen
- die nun sogar 5 gleichartig aufgebauten Blöche in eine Methode ausgliedern
sind viel wichtiger
 

Mark110

Bekanntes Mitglied
hmm irgendwie hab ich keinen ansazt wie ich die drei abshcnitt zu einem zusammenfassen kann.

kannst du ein kleines codebeispiel machen?


EDIT: hab gerade gesheen, das du bereits ein Codebeispiel gemacht hast. Werd mal veruschen das umzusetzen

Danke
 
S

SlaterB

Gast
hatte ich doch schon, der Aufruf lautet
checkCheckBox(pageEF.getCheckboxSmallVehicle(), sv);

und in diese Methode muss offensichtlich einer dieser Blöcke:

otherBodyTypsPossibleChecked = pageEF.getCheckboxOtherBodyTypesPossible().isChecked();
if (obtp.equals("-1")) {
if (!(otherBodyTypsPossibleChecked)) {
pageEF.getCheckboxOtherBodyTypesPossible().click();
}
} else {
if (otherBodyTypsPossibleChecked) {
pageEF.getCheckboxOtherBodyTypesPossible().click();
}
}


ein solcher Block hängt nur von der CheckBox und dem String mit der -1 ab,
diese beiden werden ja als Parameter übergeben, also sind alle benötigten Infos da

programmieren musst du es aber schon alleine, sonst nützt das ja nix,

-------

falls du '3 if zu einem if' meinst, das hatte ich ja auch schon gepostet
 
G

Gast

Gast
Hier ein ganz banales Beispiel:

Code:
int a = 5;
int b = 7;
int c = 6;

a = a+5;
a = a*5;
a = a+1;

b = b+5;
b = b*5;
b = b+1;

c = c+5;
c = c*5;
c = c+1;

wird zu

Code:
a = init(5);
b = init(6);
c = init(7);
...

public static int init(int start){
  start = start+5;
  start = start*5;
  start = start+1;
  return start;
}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
W Schleife und einmal variable++ zu viel Java Basics - Anfänger-Themen 20
P Geht es vielleicht viel kürzer? Java Basics - Anfänger-Themen 7
B Wieso wird hier so viel als falsch angezeigt? Java Basics - Anfänger-Themen 2
H Semikolon zu viel - ich raffs nicht.. Java Basics - Anfänger-Themen 18
O Zu viel static im Projekt Java Basics - Anfänger-Themen 9
A Ein Programm modifizieren, viel Aufwand? Java Basics - Anfänger-Themen 7
R ArrayList sehr viel schneller als Array? Java Basics - Anfänger-Themen 2
R Irgendwo ein Zeichen zu viel oder zu wenig Java Basics - Anfänger-Themen 5
S JTextArea mit LineWrap true viel zu groß! Java Basics - Anfänger-Themen 2
K Arrays - Komma zu viel, kein Problem? Java Basics - Anfänger-Themen 3
P Java erzeugt zu viel Last? Java Basics - Anfänger-Themen 15
R GridBagLayout und JTextField: Textfeld ist viel zu schmal Java Basics - Anfänger-Themen 4
T Feststellen wie viel Arbeitsspeicher belegt ist Java Basics - Anfänger-Themen 2
S die java machine läuft viel zuuuu langsam, woher kommt das?? Java Basics - Anfänger-Themen 3
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
T Kann mir jemand wörtlich erklären, was in dem Code genau passiert? Java Basics - Anfänger-Themen 1
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
terashy VS Code Project run error Java Basics - Anfänger-Themen 10
JaZuDemNo Code Erklärung Java Basics - Anfänger-Themen 3
M Connect-4-Code analysieren Java Basics - Anfänger-Themen 2
N BMI Rechner Was haltet ihr von dem Code habt ihr Verbesserungsvorschläge weil design teschnisch ist das nicht das geilste würde das gerne überarbeiten Java Basics - Anfänger-Themen 12
W In alten Code zurück- und dort wieder zurechtfinden? Java Basics - Anfänger-Themen 17
T code so schreiben das er von sich selber anpasst (code soll die anzahl aller bustaben bestimmen) Java Basics - Anfänger-Themen 16
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
T Fehlercode bei code der das Alter ausrechnet Java Basics - Anfänger-Themen 2
T Text einlesen code was kommt dahin? Java Basics - Anfänger-Themen 1
jhfjeh Strukturgramm in code Java Basics - Anfänger-Themen 11
D Tipps zum Code Java Basics - Anfänger-Themen 24
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
ohneInformatik; For Schleife. Was macht dieser Code?? Java Basics - Anfänger-Themen 5
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
Say Stelle in Code herausfinden, wie geht man vor? Java Basics - Anfänger-Themen 12
Say do-While Code Ausführung Java Basics - Anfänger-Themen 3
W Rückfrage zur Programmgestaltung (clean code) Java Basics - Anfänger-Themen 12
M intelliJ auf neuem PC, plötzlich kein Code Java Basics - Anfänger-Themen 3
Pinhg Sound in Greenfoot Code einbinden Java Basics - Anfänger-Themen 2
C Java boolean Code läuft nicht Java Basics - Anfänger-Themen 5
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
J Größter gemeinsamer Teiler: mein Code Java Basics - Anfänger-Themen 6
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
A Wie könnte man diesen Code kürzer machen ? Java Basics - Anfänger-Themen 7
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
Alen123 Warum funktioniert mein Code nicht? Java Basics - Anfänger-Themen 64
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
S Hilfe bei Umänderung von Java Code Java Basics - Anfänger-Themen 16
I Code wird nicht ausgeführt Java Basics - Anfänger-Themen 2
K Wie kann man diesen Code schnell und effizient interpretieren (Man hat nur 4 Minuten) Java Basics - Anfänger-Themen 3
R ISBN-10-Code überprüfen Java Basics - Anfänger-Themen 7
I Bitte um Hilfe zu unterstehenden Code Java Basics - Anfänger-Themen 6
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
I HTML Code säubern Java Basics - Anfänger-Themen 4
B Brauche Hilfe zu einem Code Java Basics - Anfänger-Themen 5
Temsky34 Problem mit dem Code Java Basics - Anfänger-Themen 17
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
N Java-Code abwärtskompatibel machen Java Basics - Anfänger-Themen 4
J Erste Schritte Was mache ich in meinem Code falsch. Java Basics - Anfänger-Themen 3
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
S Compiler-Fehler Nicht adressierbarer Code ( Non-addressable code ) Java Basics - Anfänger-Themen 5
Aemulit Java Schaltjahr berechnen Code Java Basics - Anfänger-Themen 7
A Code Problem Java Basics - Anfänger-Themen 6
C Fehler im Code Java Basics - Anfänger-Themen 10
A Zu einem bestimmten Ort im Code springen Java Basics - Anfänger-Themen 11
L Ist der Code richtig Java Basics - Anfänger-Themen 3
josfe1234 code vereinfachen Java Basics - Anfänger-Themen 15
nonickatall Ausführbarkeit von Code testen bzw. Remote Debugging Java Basics - Anfänger-Themen 4
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
G Programm Code Java Basics - Anfänger-Themen 5
C Code zusammenfassen Java Basics - Anfänger-Themen 5
I Erklärung zum Java Code Java Basics - Anfänger-Themen 2
T Programmablaufsplaninterpretation in Code umformen Java Basics - Anfänger-Themen 1
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
AlexVo String zu Java Anweisung getString("*** java code ***") Java Basics - Anfänger-Themen 19
M ISBN-Code Java Basics - Anfänger-Themen 26
B Zeitgleiches Arbeiten am Code mit mehreren Personen? Java Basics - Anfänger-Themen 7
S Wie kann ich bei diesem Code erreichen, das als Ergebnis hier 15 herauskommt? Java Basics - Anfänger-Themen 23
N Kann man den Code vereinfachen? Java Basics - Anfänger-Themen 25
marcooooo Code erklären Java Basics - Anfänger-Themen 28
marcooooo Code erklären Java Basics - Anfänger-Themen 4
S Advent of Code Day4 Java Basics - Anfänger-Themen 4
B Nach eingefügtem Code erkennt Compiler keine Instanzvar und meldet SyntaxError Java Basics - Anfänger-Themen 2
Gaudimagspam Caesars Code entziffern in Java Java Basics - Anfänger-Themen 8
Lukasbsc Wie kann ich meinen Code optimieren? Java Basics - Anfänger-Themen 4
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
I Input/Output Code wird doppelt ausgeführt Java Basics - Anfänger-Themen 3
T Main startet nicht bei vorgegebenen Code Java Basics - Anfänger-Themen 41
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
J Fehler im Code, aber ich weiß nicht wieso! Java Basics - Anfänger-Themen 6
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
M Code nur für Cracks? Crack the Passwort Übung Java Basics - Anfänger-Themen 7
parrot Code entferneJedeZweiteZiffer Java Basics - Anfänger-Themen 6
G Code kürzen Java Basics - Anfänger-Themen 5
Bluedaishi Source Code Signieren Java Basics - Anfänger-Themen 22

Ähnliche Java Themen

Neue Themen


Oben