Prefixes in Java alt und nicht mehr notwendig oder nützlich

Status
Nicht offen für weitere Antworten.

Ontos

Mitglied
Hallo Leute

Ich verwende seit kurzem wieder Prefixes für die Bennennung von Varialben unter Java. Eigendlich ist die Verwendung ja verpöhnt nicht mehr gerne gesehen.
collections c*
Parameter bei Methoden p*
Danach folgen klingende Variablen Bezeichnungen also z.B. cLines für eine Collection die Linien darstellt.
Eingeführt habe ich es wegen der mangelhaften final Implementierung von Sun in Bezug auf Collektions und den Fehler die daraus resultieren können.
Da ich leider der einzigste Java Coder bei mir in der Firma bin, brauche ich mal einen Realitätsabgleich was andere Firmen in dieser Richtung machen.

Wie sehen eure Firmen interen Vorschriften aus?
This überall wo es möglich ist gesetzt?
Methoden Parameter alle final gesetzt?
usw..

Super Forum habt Ihr hier! Ich hoffe das Posting ist richtig einsortiert sonst bitte verschieben und sorry!

cu Jens
 
G

Guest

Gast
Nach dem ersten Einsatz von Präfixes im Code wirst du abgemahnt. Beim zweiten verprügelt.
Beim dritten fliegst du raus und wirst verprügelt. ;)

Grund: Mann sollte sich die Definition von Klassenattributen bzw. den Code an sich vorher anschauen,
bevor man sich auf irgendwelche "Buchstaben" verlässt. Die meisten IDEs bieten auch die Funktionalität
zum ein-/ausblenden bestimmer Codeabschnitte (z.B. alle private Attribute anzeigen etc.), so dass solche
Namenskonventionen mehr die Lesbarkeit von Code erschweren als dass sie helfen.
 

messi

Bekanntes Mitglied
Probleme beim Erkennen der Variablentypen deuten meist auf allgemein schlechte Namensgebung oder eine fällige Refaktorisierung hin.

Aber es geht nicht generell gegen Präfixe und Suffixe, sondern gegen kryptische Ein-Zeichen-Kodierung. Wenn du statt "private LinkedList users;" z. B. "private LinkedList userList;" schreibst, dann ist dieses Suffix meines Erachtens völlig in Ordnung, auch wenn beim ersteren der Plural schon auf eine Collection oder einen Array hindeuten soll.

Letztlich solltest du aber auch eine gute IDE benutzen. Niemand schreibt Code in Emacs oder Notepad, wenn es IDEs gibt, die speziell für eine Sprache/Plattform geschaffen wurden.
 

Ontos

Mitglied
Moin Moin
Natürlich benutze ich eine IDE (Eclipse) :)
Wer ist den so satistisch das er Emacs für Java benutzt?

Mit dem c* für Collectionen schaffe ich einen schnelleren Zugriff auf einzelne Objecte.
Wenn ich weiß das ich in der Klasse eine Collection habe und darauf zugreifen will brauche ich nur c und automatisch vervollständigen. Schneller Zugriff auf Elemente. Das gleiche praktiziere ich bei z.B. Buttons usw. Ist das nicht Standard?
z.B. btnRunApp für einen Button der die Anwendung startet?
Das p für Methoden Paremeter habe ich eingeführt als zusätzliche Sicherheit gegen Zuweisungs Probleme (final setze ich zwar im Parameter, aber Collections können erweitert werden obwohl sie final sind! Und weil ich deswegen mal etwas länger einen Fehler gesucht habe :) )

Wie macht Ihr das den?

cu Jens
 

Sky

Top Contributor
Arbeitest Du alleine oder in einem Team?

In einem Team sollte man sich auf eine Konvention festlegen und daran sollten sich alle halten (ob nun schön oder auch nicht)

Falls Du alleine arbeitest kann es egal sein, ob Du ein c, d, x oder q als ersten Buchstaben hast...

Ich versuche meine Variablen immer so zu bennen, dass mir sofort klar ist, worum es geht (wie auch messi schon sagte besser 'userList' als 'users'). Dazu verwende ich gelegentlich auch einen Präfix (it für Iterator)
 

0xdeadbeef

Top Contributor
Beruflich programmiere ich in C und ohne IDE im Sinne des Wortes (Struktugramm-Editor).
Selbst dort ist die Typisierung innerhalb von Variablennamen verpöhnt. Und zwar hauptsächlich deshalb, weil jede Änderung des Typs eine größere Umbenennungsaktion in Source, Datenbanken und Dokumentation zur Folge hätte.
Höchstens automatische (lokale) Hilfsvariablen haben noch eine Typisierung im Namen (z.B. temp_xxx_u32).

Ich bin deshalb ehrlich gesagt auch privat komplett davon abgekommen. Letztendlich ist die Crux daran nach meinem Empfinden, daß man dann halt doch mal vergißt, den Namen an eine Typänderung anzupassen und spätestens dann ist das System völlig für die Katz: wenn man sich nicht 100% darauf verlassen kann, hat man überhaupt keinen Vorteil mehr, sondern nur noch Mehrarbeit.
 

Bleiglanz

Gesperrter Benutzer
Präfixe sind Zeitverschwendung, warum "btnRunApp" statt "runApplicationButton"?

das Erlernen und die Einhaltung der ganzen Regeln "btn", "lbl", "c", "p" usw. kostet doch nur Zeit und bringt praktisch keinen Produktivitätsgewinn

[...]dann halt doch mal vergißt, den Namen an eine Typänderung anzupassen und spätestens dann ist das System völlig für die Katz
und dass man das vorangestellte p bei einem Parameter irgendwann einmal vergisst ist wohl so gut wie sicher

kann sich noch jemand an VB6 erinnern? da gabs das Zuhauf, und fast immer wurde die "ungarische Notation" nur zur Hälfte durchgehalten (mache Labels hiessen lblXXX, andere eben nicht usw. usf)
 

Lim_Dul

Top Contributor
Meiner Ansicht nach sollten Variablen so benannt sein, dass aus ihrem Namen und dem Kontext klar hervorgeht, wofür sie gedacht ist. Das heißt der Name soll die Aufgabe der Variablen beschreiben und nicht ihren Typ. Dies hängt zwar häufig sehr eng zusammen, muss es aber nicht. Und ein Zwang auf Prefix-Regeln betont meines Erachtens den Typ der Variabeln zu sehr und legt den Fokus zuwenig auf die Aufgabe, die sie im Programm wahrnimmt.
 
G

Guest

Gast
Moin Moin

Bleiglanz hat gesagt.:
Präfixe sind Zeitverschwendung, warum "btnRunApp" statt "runApplicationButton"?

das Erlernen und die Einhaltung der ganzen Regeln "btn", "lbl", "c", "p" usw. kostet doch nur Zeit und bringt praktisch keinen Produktivitätsgewinn

Keine Gewinn?
Wenn ich ohne den Blick zu verändern oder die Maus auch nur anzufassen sofort weiß von welchem Typ ein Object ist bringt mir das einen Gewinn!
Auch grade die Auto Vervollständigen Funktion in Verbindung mit den Prefix c für Collection bringt viel.
Ich plädiere hier nicht für Prefixe für alles und jeden Typ oder die ungarische Notation sondern für einen angemessenen Umgang damit. Soviel das es Gewinn bringt, sowenig das es keine Zeit kostet.
Frage von mri nur weil ich zwar der einzigste Java Coder bei uns in der Firma bin, aber demnächst wieder Java lehren werde.

Also an alle anderen Java coder in der Industrie da draussen: Was sage eure Conventionen für bzw gegen einen verantwortungsbewusten Umgang mit Prefixes??

cu Ontos oder auch Jens
 

Bleiglanz

Gesperrter Benutzer
In Java sind sie glaub ich nicht recht beliebt und die Microsoft .NET "naming conventions" verbieten explizit den Einsatz der ungarischen Notation, ich würds also nicht übertreiben :)

komm auf keinen Fall mit
Code:
m_iIndex
für eine Member-Variable vom Typ int daher, das widerspricht auch der relativ sinnvollen Forderung, dass man Quellcode "vorlesen" können muss :)
 
B

bygones

Gast
mal so ne Frage... wie schauen denn die Abkürzungen für

Integer, int, Integer[], int[], Image, Icon

aus ?

ich stell mir das auch mit den generics interessant vor

p_c_c_i_liste für Collection<Collection<Integer>> als Parameter ?!
 

Ontos

Mitglied
Moin Moin

Bleiglanz hat gesagt.:
In Java sind sie glaub ich nicht recht beliebt und die Microsoft .NET "naming conventions" verbieten explizit den Einsatz der ungarischen Notation, ich würds also nicht übertreiben
Ihh wer will den .Net auch nur anfassen? :)
Meine Gedanken gehen an in die Richtung gleichbleibende Lesbarkeit bei einem Zusatz an Informationen.
Also nur solche Prefixe einsetzen die Gewinn bringen und das aber konsequent!

cu Jens
 

Bleiglanz

Gesperrter Benutzer
Also nur solche Prefixe einsetzen die Gewinn bringen und das aber konsequent!
welche sollten das sein? Das Problem aller Code Conventions ist doch, dass sie kurz und einfach sein müssen, damit die Programmierer es überhaupt in Betracht ziehen, sie vielleicht anzuwenden...
 

Ontos

Mitglied
deathbyaclown hat gesagt.:
p_c_c_i_liste für Collection<Collection<Integer>> als Parameter ?!

Ach nöö das ist ja absolut unlesbar und wird hoffentlich nie umgesetzt werden

ich dachte eher an sowas

Code:
Vector<DonkUser>cUsers;

Code:
Vector<Integer>cNumbers;

Das die Benennenung der Values sprechend bleibt nur ein Zusatz gewählt wird um die Plural Form zu bestimmen.
Mein Problem ist das ich ein Object user habe und einen Vector users

Code:
for (Iterator<DonkUser> iter; users.iterartor();iter.Next()){
      DonkUser user= iter.next();
}
das würde mit dem c* imho lesbarer sein

for (Iterator<DonkUser> iter; cUsers.iterartor();iter.Next()){
DonkUser user= iter.next();
}
[/code]

Und nicht so fehleranfällig bzw. cu + autovervollständigen => fertig => schneller

cu Jens
 

AlArenal

Top Contributor
Abgesehen davon, dass obiger Code Grütze ist:

Ich programmiere gegen Interfaces und benutze dann bestenfalls mal Suffixe, also userList und user, bzw. in Schleifen anstatt user curUser, o.ä.

Stichwort: "sprechende" Variablen-Namen

Ansonsten halte ich meinen Code so übersichtlich, dass ich stets eine möglichst geringe Anzahl von Variablen in einem Scope nutze. Dadurch und natürlich durch saubere Doku tue ich mir und anderen Entwicklern einen größeren Gefallen, als wenn ich irgendwelche Prefixe benutze, beim Rafactoring dann alles umwerfen muss und auch noch von Fall zu Fall unterschiedliche Regeln anwende - ob Präfix oder nicht ist ja reine Geschmackssache, der eine würde es an Stelle x gut finden, der andere blickts auch so und würde lieber an y.

Ganz oder gar nicht und dann doch besser gar nicht ;)
 
B

bygones

Gast
du beharrst ziemlich auf die Autovervollständigung, dass gehe dann schneller und weniger fehleranfällig.

Das ist doch unsinn. ob ich nun meine Liste cUser oder userList nenne - ob ich nun c+Autovervoll oder u+Autovervoll eingebe ist gleich. Fehleranfälliger ist userList auch nicht. Die IDE bietet mir ja danach nur Methoden an, die für diesen Typ zur Verfügung stehen, ebenso wird angezeigt, um was für einen Typ es sich handelt. Geschweige denn, dass er nicht kompliert, wenn ein Fehler im Code ist...

wieso ist es dann weniger fehleranfällig ??

wie schon gesagt: ich empfinde es lesbarer userList statt cUser zu nehmen..... selbst users find ich logischer.
 
G

Guest

Gast
Moin moin

Danke! Ihr habt mich überzeugt!

Wollte nur mal wieder einen Realitätsabgleich haben!

cu Jens
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
theJavaMaschine Mitstreiter gesucht: Gemeinsam Java und Android Development lernen! Allgemeine Java-Themen 5
PARAS Karriereberatung benötigt: Wie kann ich ein Java Full Stack Entwickler werden? Allgemeine Java-Themen 7
P Java Access Bridge Allgemeine Java-Themen 5
W ICEpdf PDF-Dateien werden mit Java 21 nicht nicht mehr vollständig dargestellt Allgemeine Java-Themen 3
MiMa Grundsätzliche Frage zur Verwendung von Java Versionen?? Allgemeine Java-Themen 3
OnDemand Java Deployment Vaadin Allgemeine Java-Themen 3
D Hat Java eine Library um JavaScript auszuwerten? Allgemeine Java-Themen 2
Zrebna Wieso sind eigentlich JUnit-Tests in src/test/java platziert - nur Konvention? Allgemeine Java-Themen 7
N LlaMA, KI, java-llama.cpp Allgemeine Java-Themen 39
V Java-Codierungsherausforderung: Navigieren durch die Macken der Datumsmanipulation Allgemeine Java-Themen 2
E Output Fehler (Java-Programm Kuchen) Allgemeine Java-Themen 11
M java: unexpected type Allgemeine Java-Themen 2
harrytut Java Input/Output Tests Junit Allgemeine Java-Themen 3
B Java Discord bot auf ein Root Server? Allgemeine Java-Themen 1
BetziTheRealOne Java PKIX path building failed as non Admin Allgemeine Java-Themen 15
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
KonradN Java 21 Release Allgemeine Java-Themen 5
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
K Java Anwendung machen Anleitung Allgemeine Java-Themen 5
G java.io.listFiles() Allgemeine Java-Themen 3
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
K Java-Projekt Allgemeine Java-Themen 11
K Java-Projekt Allgemeine Java-Themen 0
ruutaiokwu Welcher Browser unterstützt heutzutage noch Java Applets? Allgemeine Java-Themen 5
Jose05 Java-Klasse im extra cmd-Fenster ausführen Allgemeine Java-Themen 3
rode45e Java Threads Allgemeine Java-Themen 4
G java.io.listFiles() Allgemeine Java-Themen 2
N Java Dynamic Proxy Allgemeine Java-Themen 3
N Leichte Java Gegner Ki Allgemeine Java-Themen 10
A Java modul Problem Allgemeine Java-Themen 4
Thomasneuling Java Jar datei erstellen, von Projekt, dass auch Javafx Dateien, FXML Dateien und CSS Dateien, sowie Bilder enthält? Allgemeine Java-Themen 14
V Funktionale Schnittstelle in Java Allgemeine Java-Themen 3
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
berserkerdq2 Wenn ich bei Intelij javafx mit maven importieren will, muss ich das in die pom.xml reintun, aber warum noch in module-info.java? Allgemeine Java-Themen 3
KonradN Java 20 am 21. März Allgemeine Java-Themen 1
O Java Website Stock Bot Allgemeine Java-Themen 3
J Front-/Backend in Java Allgemeine Java-Themen 14
doopexxx JAVA Google Webcrawler Allgemeine Java-Themen 1
J JavaScript innerhalb eines Java Projekts ausführen Allgemeine Java-Themen 2
A Java Programm erstellen hilfe Allgemeine Java-Themen 10
G java.lang.NoClassDefFoundError: org/aspectj/lang/Signature Allgemeine Java-Themen 2
lalex1491 Java Aktienkurse nachfragen Allgemeine Java-Themen 4
J Class to link Java Allgemeine Java-Themen 4
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
mrStudent Inferenz JAVA Allgemeine Java-Themen 6
U URI Rechner (Java Script) Allgemeine Java-Themen 7
TheSkyRider Java Geburtsdatum Textfeld Allgemeine Java-Themen 7
mihe7 Java 19 JavaDocs: Browserintegration Allgemeine Java-Themen 1
Encera Gleichzeitiges Ausführen und verbinden von 2 Java-Klassen über die Eingabeaufforderung und Eclipse Allgemeine Java-Themen 21
H Java Rechner Programmierung der Mathematik Allgemeine Java-Themen 33
Lennox Schinkel Java Kara Auf einen Java Host laufen lassen Allgemeine Java-Themen 17
C Fußnoten von DocX mit Java Allgemeine Java-Themen 2
C Fußnoten in DocX mit Java Allgemeine Java-Themen 1
M Aussagenlogik in Java Programmieren Allgemeine Java-Themen 22
B Per Java Word Dokument schreiben? Allgemeine Java-Themen 8
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
KonradN Oracle übergibt (Java Teile der) GraalVM Community Edition an OpenJDK Community Allgemeine Java-Themen 2
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
B Java mit command line und jars benutzen? Allgemeine Java-Themen 18
M Java Überprüfen ob .exe-Datei bereits ausgeführt wird Allgemeine Java-Themen 2
B HTTP Allgemeine Fragen über Suchmaschine nutzen mit Java Allgemeine Java-Themen 20
Mick P. F. Wie kriege ich die Fehlermeldung "java: symbol lookup error: ..." weg? Allgemeine Java-Themen 11
K Nachhilfe Java Allgemeine Java-Themen 11
KonradN Java 19 Allgemeine Java-Themen 11
F IDEA IntelliJ Java Songliste erstellen Allgemeine Java-Themen 6
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
Sachinbhatt Sind alle Methoden in Java implizit virtuell Allgemeine Java-Themen 2
E Java und integrierte Grafikkarten Allgemeine Java-Themen 18
Sachinbhatt Wie wird die Typumwandlung bei Mehrfachvererbung in Java implementiert? Allgemeine Java-Themen 3
Peterw73 Hilfe bei Java gesucht Allgemeine Java-Themen 3
A Java unter Win 10 Allgemeine Java-Themen 1
B Woher kommen die Bildschirmkoordinaten beim java Robot? Allgemeine Java-Themen 14
P9cman java.Lang Klassen fehlen in JRE System Library Allgemeine Java-Themen 1
T Java Robot Class - Bot Allgemeine Java-Themen 3
E Wie Java Heap Space vergrößern? Allgemeine Java-Themen 3
B Java Programm auf virutellem Desktop laufen lassen? Allgemeine Java-Themen 1
D VBA Code mit Java ausführen möglich? Allgemeine Java-Themen 10
berserkerdq2 Threads, wie genau läuft das in Java ab? (Ich kann Threads erstellen und nutzen, nur das Verständnis) Allgemeine Java-Themen 6
izoards Java Home Pfad unabhängig von der Version Allgemeine Java-Themen 7
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
KonradN CVE-2022-21449: Fehler in Java bei Signaturprüfung Allgemeine Java-Themen 20
berserkerdq2 Java sql Allgemeine Java-Themen 15
JordenJost Unverständlicher Java code? Allgemeine Java-Themen 21
LimDul XSD To Java - Überschreiben von Assoziationen Allgemeine Java-Themen 1
Aartiyadav Comparisons and Swapa in Bubble-sort Java Allgemeine Java-Themen 6
KonradN Java 18 Allgemeine Java-Themen 8
N Statistische Auswertung von Logfiles (Einlesen, auswerten und grafische Aufbereitung von logfiles) mit Java Allgemeine Java-Themen 9
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
Z Mit Java 8+ Streams Zeilen nummern zu Zeilen hinzufügen Allgemeine Java-Themen 17
M Verständnisfrage java.util.TimerTask Allgemeine Java-Themen 2
V Hilfe mit Java Code Allgemeine Java-Themen 4
S Processing Java Code verstehen Allgemeine Java-Themen 4
O Newton Algorithmus Java Allgemeine Java-Themen 1
P Java Quellen finden Allgemeine Java-Themen 3
M Java Analyse/ SWOT-Analyse Allgemeine Java-Themen 13

Ähnliche Java Themen

Neue Themen


Oben