Problem bei Umstellung von (default package) auf Packages

Status
Nicht offen für weitere Antworten.

Soren

Mitglied
Moin, moin!

Ich habe ein kleines Problem und weiß nicht wo ich es anpacken soll. Vor Zeiten schreib ich ein Programm und war mir nicht im Klaren, dass es eines Tages sehr unübersichtlich würde: nun möchte ich es gerne auf eine vernünftige Packagestruktur umstellen. Problematisch ist nun Folgendes:

Das Programm speichert per Object In- und OutputStream ArrayListen von Transaktionen, Schlüsseln und Konten. Sagliche Klassen befinden sich in (default package). Wenn ich sie nun in ein normales Packages stecke, ist die JVM beim Auslesen der Dateien einer Vorgängerversnio der Meinung, das zu lesende Objekt gäbe es gar nicht und wirft eine ClassNotFoundException, wenn ich eine der ArrayLists lesen möchte. Warum er das tut ist klar, das einst gespeicherte Objekt kennt seine Identität und die JVM weiß nicht, dass ich im Programm dessen Namen geändert habe. Nur was mache ich nun?

Leider bin ich auf Abwärtskompatibilität zu alten Versionen meines Programms angewiesen. Kennt vielleicht jemand die Patentlösung zu meinem Problem ;-) greez


Soren
 

mic_checker

Top Contributor
Dann poste das ganze doch bitte mal konkreter. WIr wissen ja nicht wie deine Sources aussehen, welche Verzeichnisse du auf deiner Festplatte dafür erstellt hast etc.
 

Soren

Mitglied
Der gesamte Quelltext befindet sich jetzt im Arbeitsverzeichnis, das ich für das Programm angelegt habe, in

d:\E3W\Buchhaltung\

Wenn ich packages anlege, sieht das ungefähr so aus:

d:\E3W\Buchhaltung\buchhaltung

mit den speziellen Unterverzeichnissen für Funktionkomponenten, Interaktionskomponenten, Geschäftsobjekte, Hilfsklassen, usw., die dann in buchhaltung\iak, buchhaltung\fk, buchhaltung\go liegen. Im letzten liegen die Klassen, die vorher in d:\E3W\Buchhaltung\ lagen und die ich nun lesen möchte, und zwar mit dem Programm, dass die neue Verzeichnis und somit Paketstruktur kennt. Konkret sind das ArrayLists mit Transaktionen. Transaktionen sind nichts weiter als Datenbehälter mit get und set Methoden (eine Art JavaBean also).

Zu beachten ist hier, dass ich die Geschäftsobjekte nicht etwa im (default package) in d:\E3W\Buchhaltung\ belassen kann, weil sie dort von den anderen Klassen, die natürlich auf den Geschäftsobjekten arbeiten, nicht gefunden werden. Wenn ich sie allerdings nach buchhaltung.go verschiebe, dann findet die JVM die in der ArrayList enthaltenen Objekte vom Typ "Transaktion" usw. nicht mehr, da ich ihren qualifizierten Namen geändert habe, nämlich von "Transaktion" auf "buchhaltung.go.Transaktion". Das Quelltextfragment sieht so aus:

Code:
file = new File(filename);
			FileInputStream fos = new FileInputStream(filename);
			ObjectInputStream oos = new ObjectInputStream(fos);
			try
			{
                 // hier kommt eine ArrayList mit Transaktionen an
				_transaktionen = (ArrayList) oos.readObject(); 
			}
			catch (ClassNotFoundException e)
			{
				JOptionPane.showMessageDialog(
					null,
					"Dateifehler. Fehlerursache: Datei ist nicht kompatibel oder keine Buchhaltungsdatei.\n"
						+ "Das System kann die Datenbasis (Transaktionen) nicht laden.\n" +
								"\n"+e.getMessage());
			}

Die Wurzel des Übels habe ich gefunden, nur wie bringe ich der JVM bei, dass Transaktion und buchhaltung.go.Transaktion die selben Objekte sind?
 

Bert Brenner

Bekanntes Mitglied
Über einen ObjectOutputStream sollte man generell keine Daten länger speichern, da ich diese ja schon nicht mehr laden kann wenn ich änderungen an meiner Klasse mache.

Da würde ich zusehen das du die Daten künftig anders speicherst. Vielleicht kannst du die alte Klasse ja noch mal verwenden um eine art Konverter zu schreiben.
 

Soren

Mitglied
Mh, ja. Konverter schreiben wäre dann natürlich die Haudrauf-Lösung. Das Programm speichert auch jetzt schon die Daten in eine DB, leider nicht in der Version, die im Einsatz ist. Am Einsatzort ist nämlich keine DB vorhanden und wird dort auch nicht gewünscht ;-) Für die Benutzer zählt im Moment nur die Abwärtskompatibilität.

Da ich damals davon ausging, dass sich die Geschäftsobjekte nie ändern, hab ich die ObjectOutputStreams gewählt, weil es schön einfach ist. War scheinbar keine gute Wahl, denn auch wenn ich keine Änderungen an der Klasse vornehme, sondern diese nur verschiebe, ist schon alles im Dutt. Ganz offensichtlich gibt's dafür auch keinen einfachen Workaround, wie ich gehofft hatte. Naja, wenn noch jemandem was einfällt ...
 

Bert Brenner

Bekanntes Mitglied
Ok, es gibt noch einen anderen weg. :)

Ergänze deine Klasse um folgende eigenschaft:

static final long serialVersionUID = 12345L;

Den Wert der serialVersionUID setzt du auf den der alten Klasse, um diesen rauszufinden gibt es das Tool "serialver" im bin Verzeichniss vom jdk.

Dann versuch noch mal via ObjectInputStream zu lesen.
 

Soren

Mitglied
Super Idee! Das sah echt richtig aus, leider tritt der Fehler immer noch auf. Nen weiteren Handgriff kennst du da nicht, oder?

Ich habe probiert, die Klassen einfach im (default package) zu belassen und eine Kopie in der Paketstruktur anzulegen, damit er meinetwegen die (default package).Transaktion liest und dann auf buchhaltung.go.Transaktion casted, aber selbst da gibt es eine ClassCastException, obwohl der Quelltext identisch ist ... bis auf die "package" Passage. Schade :(
 

Soren

Mitglied
Noch ein Nachtrag zum Fehler: komischerweise scheint die JVM die Kopie der Transaktion im (default package) tatsächlich zu finden, auch wenn alles bereits im buchhaltung-Package ist. Die Datei wird nun geladen und der Fehler tritt erst dann auf, wenn die erste Transaktion aus der ArrayList "rausgecastet" wird. Zu dem Zeitpunkt wird nämlich die neue buchhaltung.go.Transaktion benutzt.
Die serialVersionID ist bei beiden gleich, hab ich sogar noch mal nachgeschaut...
 

Soren

Mitglied
Ganz offensichtlich betrachtet die JVM zwei von unterschiedlichen ClassLoadern geladene Klassen als unterschiedlich, auch wenn sie gleich sind: aber sogar das stimmt bei mir. Ich hab mir mal die classLoader und den qualifizierten Namen ausgeben lassen:

Code:
sun.misc.Launcher$AppClassLoader@169e11 buchhaltung.Transaktion
sun.misc.Launcher$AppClassLoader@169e11 Transaktion
Exception in thread "Thread-0" java.lang.ClassCastException: Transaktion
	at buchhaltung.DBSeitenStapel.fuege_Transaktionen_ein(DBSeitenStapel.java:59)
	at buchhaltung.Verwaltung.<init>(Verwaltung.java:56)
	at buchhaltung.Verwaltung.getInstance(Verwaltung.java:68)
	at buchhaltung.BuchHaltung.run(BuchHaltung.java:44)
[/code]

Scheinbar unterscheiden sie sich wirklich nur in ihrem Namen.
 

Soren

Mitglied
Ich habe das Problem gelöst. Ich caste nun per Hand, indem ich die Reflection Methoden des "unbekannten" Objektes aufrufe. So komme ich an dessen Methoden und auch an die Werte des Objektes! Super. Hier ist der Quellcode:

Code:
/**
     * @param object
     * @return
     */
    private Transaktion casteAufNeueTA(Object object) {

        Method get_schluessel = null;
        Method get_haben = null;
        Method get_soll = null;
        Method get_kategorie = null;
        Method get_name_lang = null;
        Method get_zweck_lang = null;
        Method get_datum = null;

        try {
            get_schluessel = object.getClass().getMethod("get_schluessel",
                    new Class[0]);
            get_haben = object.getClass().getMethod("get_haben", new Class[0]);
            get_soll = object.getClass().getMethod("get_soll", new Class[0]);
            get_kategorie = object.getClass().getMethod("get_kategorie",
                    new Class[0]);
            get_name_lang = object.getClass().getMethod("get_name_lang",
                    new Class[0]);
            get_zweck_lang = object.getClass().getMethod("get_zweck_lang",
                    new Class[0]);
            get_datum = object.getClass().getMethod("get_datum", new Class[0]);
        } catch (SecurityException e) {
            // sollte nicht passieren
            e.printStackTrace();
        } catch (NoSuchMethodException e) {
            // sollte nicht passieren
            e.printStackTrace();
        }
        Transaktion ta;
        try {
            ta = new Transaktion((String) get_name_lang.invoke(object,
                    new Object[0]), casteAufNeuenSchluessel(get_schluessel
                    .invoke(object, new Object[0])), (String) get_zweck_lang
                    .invoke(object, new Object[0]), (String) get_kategorie
                    .invoke(object, new Object[0]), ((Float) get_soll.invoke(
                    object, new Object[0])).floatValue(), ((Float) get_haben
                    .invoke(object, new Object[0])).floatValue(),
                    (Date) get_datum.invoke(object, new Object[0]));
            return ta;
        } catch (IllegalArgumentException e1) {
            // sollte nicht passieren
            e1.printStackTrace();
        } catch (IllegalAccessException e1) {
            // sollte nicht passieren
            e1.printStackTrace();
        } catch (InvocationTargetException e1) {
            // sollte nicht passieren
            e1.printStackTrace();
        }

        return new Transaktion("fehler", new Schluessel(0, "fehler"), "fehler",
                "fehler", 0, 0, new Date());

    }
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben