vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück
Rubrik: Controls · ListBox & ComboBox   |   VB-Versionen: VB.NET19.04.07
ListBox schneller füllen (VB.NET)

Durch Verwenden der BeginUpdate- und EndUpdate-Methode erfolgt das Füllen der ListBox bei größeren Datenmengen um ein vielfaches schneller.

Autor:   Dieter OtterBewertung:     [ Jetzt bewerten ]Views:  24.163 
www.tools4vb.deSystem:  WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Immer wenn eine ListBox mit größeren Datenmengen gefüllt werden soll, empfiehlt sich die Aktualisierung der ListBox auszuschalten. Das hat den Vorteil, dass das Control nicht flackert, während die Einträge hinzugefügt werden und der gesamte Vorgang auch noch um ein Vielfaches schneller ausgeführt wird.

VB.NET stellt uns hierzu zwei Methoden zur Verfügung: BeginUpdate und EndUpdate.

Anhand eines kleines Beispielprojekts haben wir einmal die Zeiten mit und ohne "BeginUpdate/EndUpdate" gemessen. Die ListBox wurde hierbei mit 25.000 Einträgen gefüllt. Ohne "BeginUpdate/EndUpdate" benötigte der Code auf unserem System 6,04 Sekunden. Durch das Abschalten der Aktualisierung brauchte der gesamte Vorgang nur noch 1.4 Sekunden.

Beispiel
Erstellen Sie ein neues Windows-Form Projekt, platzieren auf die Form1 ein ListBox-Control, ein CheckBox-Control, sowie ein Button-Control. Fügen Sie nachfolgenden Code in den Codeteil der Form ein:

Public Class Form1
 
  Private Sub Form1_Load(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles MyBase.Load
 
    ' Controls beschriften
    CheckBox1.Text = "Aktualisierung abschalten"
    Button1.Text = "Start"
  End Sub
 
  Private Sub Button1_Click(ByVal sender As System.Object, _
    ByVal e As System.EventArgs) Handles Button1.Click
 
    ' Startzeit
    Dim nTime As Date = Now
 
    With ListBox1
      ' Aktualisierung ausschalten
      If CheckBox1.Checked = True Then .BeginUpdate()
 
      ' ListBox füllen
      For i As Integer = 1 To 25000
        ListBox1.Items.Add("Eintrag " & CStr(i))
      Next
 
      ' Aktualisierung wieder einschalten
      If CheckBox1.Checked = True Then .EndUpdate()
    End With
 
    ' Benötigte Zeit anzeigen
    Me.Text = Format$(Now.Subtract(nTime).TotalSeconds, "0.#### Sek.")
  End Sub
 
End Class