Code Optimierung - Verbesserungen

M

McLovin

Gast
Hi,

ich habe nun mein Kontaktbuch mit den wichtigsten Funktionen umgesetzt. Allerdings habe ich einige Fragen zu meiner Umsetzung:
1. Das ständige umher kopieren von "phoneBook" dürfte unwahrscheinlich Performancefressend sein, gibt es da eine Möglichkeit das ohne das umherkopieren zu lösen? (Ausser das Telefonbuch statisch zu erzeugen)

2. Wo verbirgt sich der (logische) Fehler in diesem Codefragment?
Code:
System.out.println("Insert the new Tel.(otherwise leave it empty): ");
if ( (tel = sc.next()) != "")
   phoneBook.get(index-1).setTelefonNumber(tel);

3. Arbeite ich richtig mit der ArrayList?

5. Gibt es ansonsten noch Ratschläge wie ich etwas eleganter hätte lösen können oder Auffälligkeiten?

Hier meine Quelltexte:

Contact.java
Code:
public class Contact
{
	private String name;
	private String telefonNumber;
	
	Contact(String name, String telefonNumber)
	{
		this.name = name;
		this.telefonNumber = telefonNumber;
	} 
	
	/**
	 * Sets the (new) name of the contact.
	 * @param:	new name of the contact
	 */
	public void setName(String newName)
	{
		this.name = newName;
	}
	
	/**
	 * Sets the (new) telefonnumber of the contact.
	 * @param:	new telefonnumber of the contact
	 */
	public void setTelefonNumber (String newTel)
	{
		this.telefonNumber = newTel;
	}
	
	/**
	 * Returns the name of the contact.
	 * @return: name
	 */
	public String getName () 
	{
		return this.name;
	
	}
	/**
	 *	Returns the telefonnumber of the contact. 
	 * 	@return: telefonNumber
	 */
	public String getTelefonNumber() 
	{
		return this.telefonNumber;
	}
	
	
	
}

PhoneBook.java
Code:
import java.util.*;

public class PhoneBook
{	
	static Scanner sc = new Scanner(System.in); // Scanner-Object to interact with user
	static void showMenu()
	{
		System.out.println("new contact    <1>");
		System.out.println("show contacts  <2>");
		System.out.println("edit contact   <3>");
		System.out.println("delete contact <4>");
		System.out.println("exit           <0>");
		System.out.println("------------------");
	}

	static Contact newContact()
	{		
			String name;
			String tel;
			
			System.out.print("Insert the name of your contact: ");
			name = sc.next();
			System.out.print("Insert the telefonnumber of your contact: ");
			tel = sc.next();
			
			Contact con = new Contact(name, tel);
			System.out.println("Successfully created a new contact!\n");
			
			return con;
	}
	
	static void printPhoneBook(ArrayList<Contact> phoneBook, int numberContact)
	{
		for (int i = 0; i<numberContact;i++)
		{
			System.out.print( (i+1) + ": " + phoneBook.get(i).getName()+ " ");
			System.out.println("Tel.: " + phoneBook.get(i).getTelefonNumber());
		}
		
	}
	
	static ArrayList<Contact> editContact(ArrayList<Contact> phoneBook)
	{
		int index;
		String name, tel;
		System.out.println("Which contact do you want to edit? :");
		index = sc.nextInt();
		
		System.out.println("Insert the new name(otherwise leave it empty): ");
		if ( (name = sc.next()) != "")
			phoneBook.get(index-1).setName(name);
		System.out.println("Insert the new Tel.(otherwise leave it empty): ");
		if ( (tel = sc.next()) != "")
			phoneBook.get(index-1).setTelefonNumber(tel);
			
		return phoneBook;		
	}
	
	static ArrayList<Contact> deleteContact(ArrayList<Contact> phoneBook)
	{
		int index;
		System.out.print("Which contact do you want to delete? :");
		index = sc.nextInt();
		System.out.print("Do you really want to delete " + phoneBook.get(index-1).getName() + "(j/n)");
		if (sc.next() == "j")
		{
			phoneBook.remove(index-1);
		}
		
		return phoneBook;
			
	}
	 
	public static void main(String[] args)
	{
		
		ArrayList<Contact> phoneBook = new ArrayList<Contact> (5);
		int input = 1337;
		int numberContacts=0;
		
		System.out.println("Welcome to your phonebook!");
		do
		{
			showMenu();
			input = sc.nextInt();
			
			switch(input)
			{
			case 1:
					System.out.println("");
					phoneBook.add(newContact());
					numberContacts++;
					break;
			case 2: 
					System.out.println("");
					printPhoneBook(phoneBook, numberContacts);
					break;
			case 3:
					editContact(phoneBook);
					break;
			case 4: 
					System.out.println("");
					phoneBook = deleteContact(phoneBook);
					numberContacts--;
					break;
			}
			
		} while(input !=0);
	}
}

PS: Ja, bei PhoneBook war ich zu faul zu kommentieren :(

Gruß,
McLovin
 

njans

Top Contributor
1.
Also da du PhoneBook eigentlich gar nicht als Objekt hats, sondern nur statische Methoden aufrufst, weiß ich nicht genau, was du da mit "umherkopieren" meinst.

2.
if ( (tel = sc.next()) != "")
Da prüfst du auf Referenzgleichheit. Die wird wohl nicht gegeben sein, daher kriegst du auch false zurück.
 
Zuletzt bearbeitet:
M

McLovin

Gast
1.
Also da du PhoneBook eigentlich gar nicht als Objekt hats, sondern nur statische Methoden aufrufst, weiß ich nicht genau, was du da mit "umherkopieren" meinst.

Ah, mein Fehler. Ich meinte die ArrayList "phoneBook" -> die Benennung sollte ich vielleicht noch ändern.

2.
if ( (tel = sc.next()) != "")
Da prüfst du auf Referenzgleichheit. Die wird wohl nicht gegeben sein, daher kriegst du auch false zurück.

Danke. Habe direkt mal danach gegooglet - Strings werden mit .equals() vergliechen. Die Umsetzung des "Gib neuen Namen ein, ansonsten leer lassen" kriege ich dennoch nicht hin. Habe dann versucht es mit ".hasNext()" zu lösen - was auch bedingt funktioniert hat, die alte Telefonnummer wird also nicht überschrieben. Allerdings führt das "leer" lassen der Eingabe nicht, wie erwartet, dazu, dass das Bearbeiten des Kontaktes beendet und das Menü angezeigt wird - die Nächste "richtige" Eingabe(1-4) des Nutzers wird vom Programm jedoch als "Menüanweisung" erkannt und das Programm handelt korrekt darauf:

Code:
		if ( !(sc.hasNext()) )
		{
			tel = sc.next();
			phoneBook.get(index-1).setTelefonNumber(tel);
		}

Gruß,
McLovin
 
M

McLovin

Gast
Hi,

ich habe meinen Quellcode nun nocheinmal überarbeitet und die Arraylist als statisch erzeugt und mit einem anderen Namen(="contacts") versehen um den Code etwas übersichtlicher zu gestalten und das ständige umherkopieren der ArrayList zu vermeiden. Nun habe ich aber immernoch mit zwei Methoden starke Probleme:

Code:
static void editContact()
	{
		int index;
		
		String name, tel;
		System.out.println("Which contact do you want to edit? :");
		index = sc.nextInt()-1;
		
		System.out.println("Insert the new name(otherwise leave it empty): ");
		if ( !(sc.hasNext()) )
		{
			name = sc.next();
			contacts.get(index).setName(name);
		}
		
		System.out.println("Insert the new Tel.(otherwise leave it empty): ");
		if ( !(sc.hasNext()) )
		{
			tel = sc.next();
			contacts.get(index).setTelefonNumber(tel);
		}		
	}
Die Funktion funkioniert einwandfrei - insofern der Kontakt komplett umgeändert werden soll die Funktion "(otherwise leave it empty)" wird komplett übergangen.


Code:
static void deleteContact()
	{
		int index;
		
		System.out.print("Which contact do you want to delete? :");
		index = (sc.nextInt()-1);
		System.out.print("Do you really want to delete " + contacts.get(index).getName() + "? (j/n)");
		if (sc.next() == "j")
		{
			for(int i = 0; i<contacts.size();i++)
			{
				contacts.set( index+i, (contacts.get( (index+i+1) ) ) );
			}
			contacts.remove( (contacts.size()-1) );
			System.out.println("Successfully removed the contact!\n");
		}
			
	}
In der ArrayList contacts wird entgegen meinen Erwartungen der gewünschte Eintrag nicht überschrieben und der letzte Eintrag nicht gelöscht (Anders gesagt: Es geschiet nichts). Mit dem übergebenen Index dürfte das eigentlich nicht zusammenhängen, da das Programm den Namen des Kontaktes korrekt erkennt.
 
M

McLovin

Gast
Das Problem mit der Methode editContact() habe ich nun anders gelöst. Um den Namen bzw. die Tel. beizubehalten wird nun von Program die Eingabe "/e" erwartet - mich würde dennoch interessieren, wie ich die nächste Eingabe ignoriere, wenn die leer ist.

Bei der Methode removeContact() hatte ich zwei triviale Fehler: Strings nicht mit .equals() verglichen und einen Indexfehler.
 

Suinos

Bekanntes Mitglied
McLovin hat gesagt.:
das ständige umherkopieren der ArrayList zu vermeiden
Java ist nicht wie C++, wo man ständig aufpassen muss, was genau man jetzt hin und her schiebt; wenn du nur ein Objekt konstruierst (=
Code:
new
), gibt es auch wirklich nur ein Objekt!
Alle Parameter sind nur Kopien der Referenzen, also total vernachlässigbar in Sachen performance; vor allem als Anfänger (1. Schritt: Bring es zum laufen; 2. Schritt (nur für Profis): Mach es schneller).

Dann noch als Verbesserungsvorschläge:

1. All dein static raus, das zerstört das OO.
2. Ich persönlich verwende bei IO immer nur die
Code:
readLine
-Methode; so muss ich zwar die Eingabe parsen, aber habe keine Probleme mit den versteckten Zeichen (also zum Beispiel der line separator, welcher ja bei jedem Bestätigen der Eingabe mit kommt)
 
M

McLovin

Gast
Java ist nicht wie C++, wo man ständig aufpassen muss, was genau man jetzt hin und her schiebt; wenn du nur ein Objekt konstruierst (=
Code:
new
), gibt es auch wirklich nur ein Objekt!

Danke - genau das war mein Problem! Da ist Java im Vergleich mit C++ deutlich komfortabler.

1. All dein static raus, das zerstört das OO.

Danke auch hierfür - hatte das total aus den Augen verloren und war voll und ganz darauf fixiert das Telefonbuch zum laufen zubekommen. Habe hierzu auch direkt einen guten "Merksatz" auf Wipedia gefunden:
Code:
Entscheidend ist, dass bei dem jeweiligen Objektbegriff eine sinnvolle und allgemein übliche Zuordnung möglich ist.

2. Ich persönlich verwende bei IO immer nur die
Code:
readLine
-Methode; [...]

Die Methode werde ich mir noch genauer anschauen - mein Lehrbuch hatte (fast) ausschließlich mit
Code:
next
gearbeitet. Die Tage kommt aber mein neues Java-Handbuch, da kann ich dann direkt mal nachschlagen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F code Optimierung (Bin-Hex-Bytes) Java Basics - Anfänger-Themen 9
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
L Best Practice Code Refactoring für Methoden mit fast gleicher Aufbau Java Basics - Anfänger-Themen 6
L Best Practice Code refactern Java Basics - Anfänger-Themen 30
G code kürzen Java Basics - Anfänger-Themen 16
A Code umschreiben Java Basics - Anfänger-Themen 6
Torsten.E JavaFX mit Visual Studio Code verwenden Java Basics - Anfänger-Themen 1
C Beispiel-Code mit Pair wird nicht compiliert. Java Basics - Anfänger-Themen 8
X Reverse algorithm engineering (Java code) Java Basics - Anfänger-Themen 6
T Bufferedwriter code Nullpointerexception Java Basics - Anfänger-Themen 4
V Switch Methode macht Code kaputt Java Basics - Anfänger-Themen 18
R Was muss ich an meinem Code ändern? Java Basics - Anfänger-Themen 2
S Bewertet meinen Code - Part 1 Java Basics - Anfänger-Themen 8
M Java Code Verständnis Java Basics - Anfänger-Themen 4
M Java Code Verständnis Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben