


JTable-doppelte Werte in Zeile
Das Füllen einer JTable mit einem benutzerdefinierten Datenmodell kann gelegentlich zum unerwarteten Auftreten doppelter Daten in den Tabellenzeilen führen . Auch wenn dies auf ein Problem mit dem DataModel hindeuten könnte, offenbart eine nähere Betrachtung oft etwas anderes, sodass die Ursache dieses Verhaltens ein Rätsel bleibt.
Eine mögliche Erklärung für dieses Phänomen liegt in der Implementierung der JTable selbst. Wenn ein DataModel zum Füllen einer JTable verwendet wird, werden die gerenderten Werte in der Tabelle direkt von der getValueAt-Methode des DataModel abgeleitet. Wenn diese Methode den eindeutigen Wert für jede Zelle in der Tabelle nicht korrekt abrufen kann, werden die gerenderten Werte über mehrere Zeilen hinweg dupliziert.
Um dieses Problem zu beheben, muss unbedingt sichergestellt werden, dass die getValueAt-Methode immer den zurückgibt Sollwert für jede Zelle. Dies kann erreicht werden, indem die zugrunde liegende Datenstruktur, die vom DataModel verwendet wird, ordnungsgemäß gefüllt wird. Im Fall des bereitgestellten DataModel füllt die Methode „populate“ die Daten-ArrayList mit Datenzeilen. Wenn jedoch der Code, der diese ArrayList auffüllt, jeder Zeile nicht korrekt eindeutige Werte zuweist, werden in der resultierenden Tabelle doppelte Werte angezeigt.
Zur Erinnerung: Es reicht nicht aus, nur die getValueAt-Methode zu ändern, um eindeutige Werte zurückzugeben Werte, da das zugrunde liegende Problem dadurch nicht behoben wird. Stattdessen sollte der Schwerpunkt darauf liegen, sicherzustellen, dass die Datenstruktur, die zum Auffüllen des Datenmodells verwendet wird, von Anfang an die richtigen Daten enthält. Durch die Adressierung der Datenquelle kann verhindert werden, dass doppelte Werte in der JTable angezeigt werden.
Um ein konkreteres Beispiel zu liefern, betrachten Sie den folgenden Codeausschnitt:
import java.util.ArrayList; import javax.swing.table.AbstractTableModel; public class CollectionDataModel extends AbstractTableModel { private ArrayList<arraylist>> data; public CollectionDataModel() { data = new ArrayList<arraylist>>(); } @Override public int getColumnCount() { if (data.isEmpty()) return 0; return data.get(0).size(); } @Override public int getRowCount() { return data.size(); } @Override public Object getValueAt(int rowIndex, int columnIndex) { if (rowIndex >= getRowCount()) return null; if (columnIndex >= getColumnCount()) return null; return data.get(rowIndex).get(columnIndex); } public void populate(Collection c) { data.clear(); for (Item i : c.getItems()) { ArrayList<string> row = new ArrayList<string>(); for (Property p : i.getProperties().values()) { row.add(p.toString()); } data.add(row); } fireTableDataChanged(); } }</string></string></arraylist></arraylist>
In diesem Code , füllt die Methode „populate“ die Daten-ArrayList mit Datenzeilen, die vom Collection-Objekt abgerufen wurden. Um doppelte Werte in der JTable zu vermeiden, muss unbedingt sichergestellt werden, dass jede Zeile in der ArrayList eindeutige Daten enthält. Dies kann erreicht werden, indem vor dem Hinzufügen neuer Zeilen zur ArrayList überprüft wird, ob doppelte Daten vorhanden sind, oder indem eine Datenstruktur verwendet wird, die Eindeutigkeit erzwingt.
Durch die direkte Adressierung der Datenquelle ist es möglich, doppelte Werte zu verhindern erscheint in der JTable. Dieser Ansatz ist zuverlässiger und effizienter als die Manipulation der getValueAt-Methode, da er sicherstellt, dass die zugrunde liegenden Daten von Anfang an korrekt sind.
Das obige ist der detaillierte Inhalt vonWarum zeigen meine JTable-Zeilen doppelte Werte an, wenn ich ein benutzerdefiniertes Datenmodell verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Java wird aufgrund seiner Unabhängigkeit der Plattform in Anwendungen auf Unternehmensebene häufig verwendet. 1) Die Unabhängigkeit der Plattform wird über Java Virtual Machine (JVM) implementiert, sodass der Code auf jeder Plattform ausgeführt wird, die Java unterstützt. 2) Sie vereinfacht die plattformübergreifenden Bereitstellungs- und Entwicklungsprozesse und bieten mehr Flexibilität und Skalierbarkeit. 3) Es ist jedoch notwendig, auf Leistungsunterschiede und die Kompatibilität der Bibliotheksbibliothek zu achten und Best Practices wie die Verwendung von reinen Java-Code und plattformübergreifenden Tests einzusetzen.

JavaplaysaSignificantroleiniotduetoitsplattformindependence.1) ItallowsCodetobewrittenonceandrunonvariousDevices.2) Java'secosystemProvideburlibibrarysForiot.3) ErschöpfungsmusternhanzeIsStemsFepyStemsafaftEdEpety

ThemeolutionToHandleFilepathsacrosswindowsandlinuxinjavaistousepaths.get () von Thejava.nio.FilePackage.1) usepaths

Java'splatformindependenceissignificantbecauseitallowsdeveloperstowritecodeonceandrunitonanyplatformwithaJVM.This"writeonce,runanywhere"(WORA)approachoffers:1)Cross-platformcompatibility,enablingdeploymentacrossdifferentOSwithoutissues;2)Re

Java eignet sich für die Entwicklung von Cross-Server-Webanwendungen. 1) Javas Philosophie "einmal schreiben, überall rennen" lässt ihren Code auf jeder Plattform ausgeführt, die JVM unterstützt. 2) Java verfügt über ein reichhaltiges Ökosystem, einschließlich Tools wie Frühling und Winterschlaf, um den Entwicklungsprozess zu vereinfachen. 3) Java spielt hervorragend in Bezug auf Leistung und Sicherheit und bietet effizientes Speichermanagement und starke Sicherheitsgarantien.

JVM implementiert die Wora-Merkmale von Java durch Bytecode-Interpretation, plattformunabhängige APIs und dynamische Klassenbelastung: 1. Bytecode wird als Maschinencode interpretiert, um einen plattformübergreifenden Betrieb sicherzustellen. 2. Unterschiede zwischen API -abstrakter Betriebssystem; 3. Die Klassen werden zur Laufzeit dynamisch geladen, um eine Konsistenz zu gewährleisten.

Die neueste Version von Java löst effektiv plattformspezifische Probleme durch JVM-Optimierung, Standardbibliotheksverbesserungen und Unterstützung von Drittanbietern. 1) JVM -Optimierung, wie der ZGC von Java11, verbessert die Leistung der Müllsammlung. 2) Standardbibliotheksverbesserungen wie das Modulsystem von Java9, das plattformbedingte Probleme reduziert. 3) Bibliotheken von Drittanbietern bieten plattformoptimierte Versionen wie OpenCV.

Der Bytecode -Überprüfungsprozess des JVM enthält vier wichtige Schritte: 1) Überprüfen Sie, ob das Klassendateiformat den Spezifikationen entspricht, 2) Überprüfen Sie die Gültigkeit und Korrektheit der Bytecode -Anweisungen, 3) die Datenflussanalyse durchführen, um die Sicherheitstypsicherheit zu gewährleisten, und 4) Ausgleich der gründlichen Überprüfung und Leistung der Verifizierung. Durch diese Schritte stellt die JVM sicher, dass nur sichere, korrekte Bytecode ausgeführt wird, wodurch die Integrität und Sicherheit des Programms geschützt wird.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung
