Aufrufer einer Funktion ermitteln

multiholle

Aktives Mitglied
Wie kann ich ermitteln, welches Obejekt die Funktion einer Klasse aufgerufen hat? In etwas so:
Java:
public ClassA {
  public static void something() {
    ClassB.anything();
  }
}

public ClassB {
  public static void anything() {
    String className = ...; // "ClassA"
    System.out.println("called anything() from " + className);
  }
}
 

Ebenius

Top Contributor
Gar nicht. Zum Logging, kann man den Namen der Klasse und Methode ermitteln: Thread.getStackTrace(). Mehr aber nicht.

Üblicherweise ist der Bedarf einer solchen Funktionalität ein Zeichen für einen Design-Fehler. ;-)

Ebenius
 

MQue

Top Contributor
Ich würds, wenn man das schon benötigt, so ungefähr machen, also weg mit den Klassenmethoden -> Klassenmethoden und Klassenvariablen würde ich nur selten verwenden, static - Methoden und Variablen gibts nur ein einziges mal für eine Klasse und alle Objekte teilen sich die static Dinger.

Java:
package classinvokation;

class ClassA {
  public void something() {
    ClassB cb = new ClassB();
    cb.anything(this);
  }

    @Override
  public String toString() {
    return "[ClassA: " + this.hashCode() + ", " + this.getClass() + "]";
    }
}

class ClassB {
  public void anything(ClassA ca) {
    String className = ca.toString();
    System.out.println("called anything() from " + className);
  }
}

public class Main {

    public Main() {
        ClassA ca = new ClassA();
        ca.something();
        }

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

Gast2

Gast
Das ist doch Murks. Bringt in diesem speziellen Fall was, aber dann kannst du auch gleich jeder Funktion noch drei weitere Paramter mitgeben:

Java:
public void irgendEineFunktion(String param1, String param2, 
                   String callingClassname, String callingClassFunktion, int callingClassLineNr){
System.out.println("Was called by "+callingClassname+"."+callingClassFunktion
     +"("+param1+", "+param2+") at line "+callingClassLineNr);
}

Aber ich schließe mich da Ebenius an, der sinn dahinter leuchtet mir auch nicht ein, bzw sollte es den Bedarf gar nicht geben. (Höchstens zu Demonstrationszwecken)
 

MQue

Top Contributor
Das ist doch Murks. Bringt in diesem speziellen Fall was, aber dann kannst du auch gleich jeder Funktion noch drei weitere Paramter mitgeben:

Java:
public void irgendEineFunktion(String param1, String param2, 
                   String callingClassname, String callingClassFunktion, int callingClassLineNr){
System.out.println("Was called by "+callingClassname+"."+callingClassFunktion
     +"("+param1+", "+param2+") at line "+callingClassLineNr);
}

Aber ich schließe mich da Ebenius an, der sinn dahinter leuchtet mir auch nicht ein, bzw sollte es den Bedarf gar nicht geben. (Höchstens zu Demonstrationszwecken)

Was ist denn mit dir los, mir ist auch nichts besseres eingefallen für diesen Problemfall, hätte ja sein können, dass für den TO ein anderes Design ohne static auch möglich ist. Das gleich als Murks zu bezeichnen ohne einen besseren Vorschlag zu liefern find ich schwach außerdem musst du das schon dem TO überlassen.
 

multiholle

Aktives Mitglied
Der Hintergrund des ganzen liegt in der Ausgabe von Informationen/Warnungen/Fehler. Ich wollte eine Tool-Klasse schreiben, die diese Funktionen zur Statusausgabe zur Verfügung stellt. Ich möchte einen String als Meldung an diese Funktion übergeben und die Tool Klasse sollte dann so eine Ausgabe erzeugen:

Code:
[28.01.2010 13:51:32.3] ExampleClass: Everything is OK.

"ExampleClass" wäre dann die Klasse, die die Information ausgibt. Ließe sich das auch noch anders realisieren?
 

MQue

Top Contributor
Wenn nur der Klassenname ausgegeben werden soll, woher die Meldung kommt, dann würde ich dir nochmal meinen Code empfehlen,
 

multiholle

Aktives Mitglied
Ich habe es jetzt so gelöst, ist das in Ordnung?
Java:
package tools;

import java.io.PrintStream;
import java.text.SimpleDateFormat;
import java.util.Date;

public class Console {
	public static void printInfo(String info) {
		// Aktuellen StackTrace holen
		StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
		// Aufrufende Klasse ermitteln
		String callingClass = stackTrace[2].getClassName();
		// Ausgabe
		print(info, callingClass, System.out);
	}
	
	public static void printError(String error) {
		// Aktuellen StackTrace holen
		StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
		// Aufrufende Klasse ermitteln
		String callingClass = stackTrace[2].getClassName();
		// Ausgabe
		print(error, callingClass, System.err);
	}
	
	private static void print(String message, String callingClass, PrintStream output) {
		// Datumsformat festlegen
		SimpleDateFormat dateFormat = new SimpleDateFormat("dd.MM.yyyy HH:mm:ss");
		// Info zusammenbauen und ausgeben
		output.println(
				"[" + dateFormat.format(new Date()) + "] " +
				callingClass + ": " + message);		
	}
}
 
Zuletzt bearbeitet:
S

SlaterB

Gast
wenn du mit der Verschachtelung aufpasst, könnte der doppelte Code

// Aktuellen StackTrace holen
StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
// Aufrufende Klasse ermitteln
String callingClass = stackTrace[2].getClassName();

auch direkt in die print-Methode ab Zeile 26,
dann nur stackTrace[3] und darauf aufpassen, dass niemand die Methode direkt aufruft ;)
 

multiholle

Aktives Mitglied
Hier noch etwas kürzer. Bin soweit ganz zu frieden. Die Ausgabe sieht dann so aus:
Code:
[28.01.2010 15:33:55] communication.client.Client: 3 + 2 = 5
Java:
import java.io.PrintStream;
import java.text.SimpleDateFormat;
import java.util.Date;

public class Console {
	public static void printInfo(String info) {
		print(info, System.out);
	}
	
	public static void printError(String error) {
		print(error, System.err);
	}
	
	private static void print(String message, PrintStream output) {
		// Aktuellen StackTrace holen
		StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
		// Aufrufende Klasse ermitteln
		String callingClass = stackTrace[3].getClassName();
		// Datumsformat festlegen
		SimpleDateFormat dateFormat = new SimpleDateFormat("dd.MM.yyyy HH:mm:ss");
		// Info zusammenbauen und ausgeben
		output.println(
				"[" + dateFormat.format(new Date()) + "] " +
				callingClass + ": " + message);		
	}
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
T Aufrufer einer Methode identifizieren Allgemeine Java-Themen 2
T Aufrufer identifizieren Allgemeine Java-Themen 12
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
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
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
T Compiler-Fehler NoClassDefFoundError beim Laden einer Class Allgemeine Java-Themen 11
H Klassen LibGDX - Verschiedene Klassen als Value in einer Map Allgemeine Java-Themen 8
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
E Elemente innerhalb einer ArrayList vergleichen Allgemeine Java-Themen 33
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
temi Java Programm aus einer DB laden und starten Allgemeine Java-Themen 2
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
ReinerCoder Methode einer Klasse meldet Fehler "misplaced construct(s)" Allgemeine Java-Themen 13
L Fehler bei der Ausführung einer Jar Allgemeine Java-Themen 2
Javafan01 Deklarieren einer Math.random() Zufallszahl Allgemeine Java-Themen 16
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
H Laden einer (Resourcendatei) aus einem Jar-File Allgemeine Java-Themen 17
P Array einer abstrakten Klasse Allgemeine Java-Themen 4
J Teil einer URL auslesen Allgemeine Java-Themen 13
J Ordner und Datei Struktur einer War Datei Allgemeine Java-Themen 1
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12

Ähnliche Java Themen

Neue Themen


Oben