Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren?

  • Themenstarter MarkusFromBerne
  • Beginndatum
M

MarkusFromBerne

Mitglied
Ich habe ein Programm, das mitzählt, wie viele Objekte einer Klasse instanziiert werden. Die Zählervariable habe ich als static definiert, weil es zur Klasse und weniger zu den einzelnen Objekten gehört. "Static" habe ich so verstanden, dass damit Variablen und Methoden bezeichnet werden, die nur die Klasse benutzen darf, die aber bei den Objekten dieser Klasse nicht mit-instanziiert werden.

Das Programm läuft so wie ich mir das vorstelle.
Zum Testen habe ich geschaut, was geschieht, wenn ich die static Variable mit einem Objekt verknüpfe:
object.staticVariable
Nach meiner Überlegung sollte das nicht möglich sein, da "object" gar keine eigene "staticVariable" besitz. Die "staticVariable" ist ja nur in der Klasse vorhanden.
Habe ich da eine misconception?

Das Einige, was ich mir vorstellen kann: Der Kompiler sagt sich quasi "oh, object hat gar kein staticVariable. Na dann ist sicher das staticVariable der Klasse gemeint. Ich geb' mal das aus".
Das ist zwar halbwegs logisch, aber mE dennoch unsinnig, weil ja dann alle Objekte die gleiche staticVariable "besitzen". Object1.staticVariable = Object2.staticVariable =Objectn.staticVariable

Wo liegt mein Denkfehler?
Danke& Gruss,
MarkusFromBerne

Java:
public class test{
  public static void main( String[] args ){

    //Hier werden 3 Objekte instanziiert und anschliessend auf der Kommandozeile zusammengefasst.
    objecttest a1 = new objecttest("Stuhl", 20);
    a1.informUserAboutCreation();

    objecttest a2 = new objecttest("Tisch", 33);
    a2.informUserAboutCreation();

    objecttest a3 = new objecttest("Flasche", 1);
    a3.informUserAboutCreation();

    //Hier ist das statement, bei dem mir unklar ist, warum es erlaubt ist.
    System.out.println(a1.counterOfNumberOfInstances);
  }
}

class objecttest {
  //Hier die statische Variable
  static int counterOfNumberOfInstances;

  String name;
  int value;

  public objecttest(String name, int value) {
    this.name = name;
    this.value = value;
    //Bei jedem Konstruktor-Aufruf wird der counter um 1 raufgesetzt.
    counterOfNumberOfInstances++;
  }

  public void informUserAboutCreation (){
    System.out.println("Ein neues Objekt wurde geschaffen:\nEs heisst "+name+ " und hat den Wert "+value+ ". \nEs ist das "+counterOfNumberOfInstances+". Objekt dieser Klasse.\n");
  }
}
 
H

httpdigest

Top Contributor
Das Einige, was ich mir vorstellen kann: Der Kompiler sagt sich quasi "oh, object hat gar kein staticVariable. Na dann ist sicher das staticVariable der Klasse gemeint. Ich geb' mal das aus".
Ganz genau das ist der Fall. Bei einem Ausdruck der Form `x.y` versucht der Compiler, den Namen 'y' an dem Compilezeittyp vom Ausdruck 'x' aufzulösen. Wenn das eine statische Variable ist, dann interessiert den Compiler die Instanz, die von 'x' zurückgeliefert wird, nicht mehr, sondern der Compiler generiert hier dann einfach einen statischen Zugriff auf 'y' basierend auf dem statischen/Compilezeittyp des Ausdrucks 'x'.
Ein Zugriff auf einen statischen Member über eine Objektinstanz generiert allerdings eine Warnung in jeder IDE und (ich bin mir sicher) auch in javac.
 
M

MarkusFromBerne

Mitglied
Ganz genau das ist der Fall. Bei einem Ausdruck der Form `x.y` versucht der Compiler, den Namen 'y' an dem Compilezeittyp vom Ausdruck 'x' aufzulösen. Wenn das eine statische Variable ist, dann interessiert den Compiler die Instanz, die von 'x' zurückgeliefert wird, nicht mehr, sondern der Compiler generiert hier dann einfach einen statischen Zugriff auf 'y' basierend auf dem statischen/Compilezeittyp des Ausdrucks 'x'.
Ein Zugriff auf einen statischen Member über eine Objektinstanz generiert allerdings eine Warnung in jeder IDE und (ich bin mir sicher) auch in javac.
@httpdigest : Danke für deine Antwort, dann lag ich also richtig mit meiner Vermutung.
In der IDE (visual code studio) wurde das statement gekräuselt unterstrichen, aber kompiliert wurde anstandslos.
 
kneitzel

kneitzel

Top Contributor
Das ist dann so eine typische Warnung. Da einfach mal mit der Maus drauf gehen oder so. Dann sollte eine Meldung dazu eingeblendet werden.
 
M

MarkusFromBerne

Mitglied
Das ist dann so eine typische Warnung. Da einfach mal mit der Maus drauf gehen oder so. Dann sollte eine Meldung dazu eingeblendet werden.
Die Meldung (" The static field objecttest.counterOfNumberOfInstances should be accessed in a static wayJava(570425420) ") habe ich natürlich brav vor meinem Post angeschaut. Aber sie erklärt nur, wie man eigentlich sollte und nicht warum es trotzdem geht.
Trotzdem Danke
 
kneitzel

kneitzel

Top Contributor
Das war dann natürlich von Dir eine perfekte Vorarbeit. Das sollte von mir auch nur ein kleiner Hinweis sein, falls Dir das etwas entgangen wäre.
 
A

affot

Mitglied
Wie man es eigentlich mache (sofern ich es jetzt hier nicht überlesen habe): objecttest.counterOfNumberOfInstances, also über den Klassennamen.
Und gewöhn dir besser an, Klassennamen groß zu schreiben.
 
W

White_Fox

Top Contributor
weil es zur Klasse und weniger zu den einzelnen Objekten gehört
Versuche es mal mit "gehört zu allen Objekten der Klasse", das macht die Verwendung von static vielleicht etwas klarer.

Eine Klasse ist nur eine Blaupause für ein Objekt - mehr nicht. Sie beschreibt, was ein Objekt an Daten hält (eben die Membervariablen), beschreibt die Schnittstellen nach außen (Methoden, implementierte Interfaces), und was da intern geschieht. Insofern gibt es keine Variablen, die zur Klasse gehören.

Mein Prof sagte damals immer: Sie haben einen Bauplan für einen Bagger. Sie können gerne mal versuchen, mit einem Bauplan ein Loch zu buddeln - das geht schlecht. Sie können sich aber mit dem Bauplan einen Bagger bauen, und mit dem können sie dann ein Loch buddeln.

Du kannst eine Klasse ja auch beliebig oft instanziieren, dir also beliebig viele Objekte eines Typs bauen (wenn du das nicht gerade absichtlich blockierst). Aber den Bauplan erstellst du nur ein einziges Mal.
 
mrBrown

mrBrown

Super-Moderator
Mitarbeiter
Versuche es mal mit "gehört zu allen Objekten der Klasse", das macht die Verwendung von static vielleicht etwas klarer.

Eine Klasse ist nur eine Blaupause für ein Objekt - mehr nicht. Sie beschreibt, was ein Objekt an Daten hält (eben die Membervariablen), beschreibt die Schnittstellen nach außen (Methoden, implementierte Interfaces), und was da intern geschieht. Insofern gibt es keine Variablen, die zur Klasse gehören.

Mein Prof sagte damals immer: Sie haben einen Bauplan für einen Bagger. Sie können gerne mal versuchen, mit einem Bauplan ein Loch zu buddeln - das geht schlecht. Sie können sich aber mit dem Bauplan einen Bagger bauen, und mit dem können sie dann ein Loch buddeln.

„gehört allen Objekten“ finde ich in dem Fall eher Kontraproduktiv, zu einer Klasse gehörend passt da schon besser. Es ist eben völlig unabhängig von allen Objekten, egal ob noch nie ein Objekt erzeugt wurde, oder auch wenn (normal) gar keine Objekte erzeugt werden können.

Um bei dem Bagger-Bauplan-Beispiel zu bleiben: static ist die Strichliste, die jemand an den Rand des Bauplans gekritzelt hat. Da würde ja auch niemand sagen, die gehört zu allen Baggern, sondern eben nur zum Bauplan.

(Theoretisch kann man auch mehrere Baupläne haben, die alle ihre eigene Strichliste haben, aber damit kommt der normale Nutzer nicht wirklich in Berührung)
 
M

MarkusFromBerne

Mitglied
Wie man es eigentlich mache (sofern ich es jetzt hier nicht überlesen habe): objecttest.counterOfNumberOfInstances, also über den Klassennamen.
Und gewöhn dir besser an, Klassennamen groß zu schreiben.
@affot : Danke auch für den Hinweis mit der Grossschreibung des Klassennamens, ich bin dran.

„gehört allen Objekten“ finde ich in dem Fall eher Kontraproduktiv, zu einer Klasse gehörend passt da schon besser. Es ist eben völlig unabhängig von allen Objekten, egal ob noch nie ein Objekt erzeugt wurde, oder auch wenn (normal) gar keine Objekte erzeugt werden können.

Um bei dem Bagger-Bauplan-Beispiel zu bleiben: static ist die Strichliste, die jemand an den Rand des Bauplans gekritzelt hat. Da würde ja auch niemand sagen, die gehört zu allen Baggern, sondern eben nur zum Bauplan.

(Theoretisch kann man auch mehrere Baupläne haben, die alle ihre eigene Strichliste haben, aber damit kommt der normale Nutzer nicht wirklich in Berührung)
@mrBrown : Danke für das Bagger-Beispiel, das hat mir geholfen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M nur Ziffern dürfen eingetippt werden Java Basics - Anfänger-Themen 10
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
P Globale Objekte Java Basics - Anfänger-Themen 2
C Nachträglich neue grafische Objekte hinzufügen Java Basics - Anfänger-Themen 7
D Interaktion zweier Objekte Java Basics - Anfänger-Themen 5
M Objekte in Array speichern und ausgeben Java Basics - Anfänger-Themen 17
S Objekte indiziert erstellen Java Basics - Anfänger-Themen 27
M Objekte mittels equals vergleichen Java Basics - Anfänger-Themen 14
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
A (Objekte Java Basics - Anfänger-Themen 6
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
U Objekte in einer LinkedList sortieren Java Basics - Anfänger-Themen 5
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
G Java Objekte auf Duplikate testen Java Basics - Anfänger-Themen 4
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
M Implementieren einer Datenstruktur, welche nur 5 Objekte speichert Java Basics - Anfänger-Themen 3
M Objekte miteinander vergleichen Java Basics - Anfänger-Themen 18
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
J Java GUI- Objekte Position per Quelltext bestimmen Java Basics - Anfänger-Themen 4
G Objekte in Methoden? Java Basics - Anfänger-Themen 13
H Auf Objekte bzw Variabeln aus einer anderen Methode zugreifen Java Basics - Anfänger-Themen 7
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
K Boolean in einer Methode um 2 Objekte zu vergleichen Java Basics - Anfänger-Themen 12
I Objekte Hilfe Java Basics - Anfänger-Themen 8
G Klassen und Objekte Java Basics - Anfänger-Themen 2
W Verschachtelte Objekte wieder auspacken Java Basics - Anfänger-Themen 3
R Attribute mehrerer Objekte ausgeben Java Basics - Anfänger-Themen 3
C Objekte und Konstruktoren Java Basics - Anfänger-Themen 2
F Erstellen zweier Objekte mit dem selben Inhalt Java Basics - Anfänger-Themen 1
O ObjectOutputStream Anzahl Objekte festhalten Java Basics - Anfänger-Themen 17
R Objekte aus Array als String + kommasepariert speichern Java Basics - Anfänger-Themen 12
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
J Best Practice Dateiinhalte validieren und auf Objekte mappen Java Basics - Anfänger-Themen 3
B Automatisch Objekte erzeugen mit verschiedenen Namen Java Basics - Anfänger-Themen 4
der_Schokomuffin Hilfe gesucht beim Thema Objekte übergeben! Java Basics - Anfänger-Themen 2
S Konstruktor, Objekte Java Basics - Anfänger-Themen 4
PaperHat Objekte in Array vergleichen Java Basics - Anfänger-Themen 9
B HTML Code / Seite auslesen und JAVA Objekte erstellen Java Basics - Anfänger-Themen 12
PaperHat Programmieraufgabe - Objekte in Objekten Java Basics - Anfänger-Themen 2
E Methode mit Parametern um Objekte zu übergeben Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
T Klassen Klassenübergreifende Objekte erstellen lassen Java Basics - Anfänger-Themen 5
A Objekte verknüpfen Java Basics - Anfänger-Themen 2
M Objekte mit einer Schleife mehrmals erzeugen Java Basics - Anfänger-Themen 17
B Klassen Alle Unter-Objekte durchlaufen in der Hauptklasse Java Basics - Anfänger-Themen 10
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
J Methoden Equals Methode für Integer und Objekte überschreiben? Java Basics - Anfänger-Themen 9
B Erste Schritte Objekte von JFrame der Fenstergröße anpassen Java Basics - Anfänger-Themen 3
M Klassen und Objekte Java Basics - Anfänger-Themen 2
J Objekte und Abstrakte Klassen Java Basics - Anfänger-Themen 2
J Array Objekte einer Klasse zuordnen Java Basics - Anfänger-Themen 15
H Interface Objekte speichern und laden (serialisieren/deserialisieren) Java Basics - Anfänger-Themen 1
Orkanson Objekte in ein Array einfügen Java Basics - Anfänger-Themen 5
X Objekte in ArrayList einfügen Java Basics - Anfänger-Themen 10
L Vorherige Objekte zählen und ausgeben Java Basics - Anfänger-Themen 11
Orkanson Objekte und Klassen Java Basics - Anfänger-Themen 8
R Objekte zur Laufzeit in Schleife erzeugen und in ArrayList ablegen Java Basics - Anfänger-Themen 4
D Objekte-Fragen Java Basics - Anfänger-Themen 1
T Objekte in der Methode Java Basics - Anfänger-Themen 8
F Alle Objekte einer Klasse nach Eigenschaft durchsuchen Java Basics - Anfänger-Themen 8
R Interface Eigene Objekte in Listen sortieren mit Interface Comparable Java Basics - Anfänger-Themen 5
E Eine Instanzvariable und zwei Objekte Java Basics - Anfänger-Themen 14
N Objekte in ArrayList finden Java Basics - Anfänger-Themen 10
K Comparable - Objekte aus Array vergleichen und größtes auswählen Java Basics - Anfänger-Themen 1
R getrennte Objekte aus Klasse erstellen : warum Inhalt dann gleich ? Java Basics - Anfänger-Themen 2
T Objekte in Listen vererben Java Basics - Anfänger-Themen 3
E Methoden Objekte in Methode aufrufen ohne getter und setter? Java Basics - Anfänger-Themen 1
A Variablen In anderer Klasse auf Objekte von JFrame zugreifen Java Basics - Anfänger-Themen 1
R Objekte Vergleichen und Sortieren Java Basics - Anfänger-Themen 3
BobbGott Klassen 2 "Objekte" in einer Methode - wie? Java Basics - Anfänger-Themen 7
S Objekte mit gleichem Namen in unterschiedlichen Klassen Java Basics - Anfänger-Themen 3
S Objekte "gegebenfalls" erzeugen Java Basics - Anfänger-Themen 5
F Klassen Zugriff auf verschachtelte Objekte Java Basics - Anfänger-Themen 11
H Objekt überschreibt Variablen vorheriger Objekte Java Basics - Anfänger-Themen 2
snipesss Objekte Java Basics - Anfänger-Themen 14
tuc Erste Schritte verschiedene objekte in einem feld speichern Java Basics - Anfänger-Themen 4
J Objekte in einer Liste Java Basics - Anfänger-Themen 3
D Mehrere Objekte in ein Objekt zusammenfassen Java Basics - Anfänger-Themen 16
W OOP Zwei Objekte beziehen sich aufeinander (Zirkelbezug)? Java Basics - Anfänger-Themen 4
D Objekte mit verschiedenen Attributen erstellen Java Basics - Anfänger-Themen 3
A OOP Zugriff auf Objekte von außen Java Basics - Anfänger-Themen 8
T Objekte mit Verhalten Java Basics - Anfänger-Themen 14
Z OOP Objekte einer Klasse weiteren Klassen zur Verfügung stellen Java Basics - Anfänger-Themen 17
T Objekte erstellen Java Basics - Anfänger-Themen 2
D Methoden Wie können Klassen auf Klassenfremde Objekte zugreifen? Java Basics - Anfänger-Themen 7
G Datentypen verschiedene Objekte in eine ArrayList, Generics Java Basics - Anfänger-Themen 2
D Statische Objekte mit variablem Parameter Java Basics - Anfänger-Themen 1
K Mehrere Objekte anlegen Java Basics - Anfänger-Themen 23
S Objekte klonen und Deep Copy Java Basics - Anfänger-Themen 30
D Objekte in Liste eintragen Java Basics - Anfänger-Themen 4
H Mit Schleife erstellte gleichnamige Objekte einzeln anwählen? Java Basics - Anfänger-Themen 1
P verständnis Frage Refernzen und Objekte Java Basics - Anfänger-Themen 1
C Methoden Objekte und Methode und Übergabe Java Basics - Anfänger-Themen 4
E Objekte und static Java Basics - Anfänger-Themen 2
EisKaffee Klassen Objekte verwalten Java Basics - Anfänger-Themen 13
boscho87 Objekte übergeben Best Practice Java Basics - Anfänger-Themen 1
K Nachträglich auf Objekte zugreifen Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Anzeige

Neue Themen


Oben