Dieser Tipp zeigt, wie man den Arbeitsspeicher bei Speicherengpässen optimieren kann.
Und hier der benötigte Code: ' API´s und Konstanten Private Declare Sub GlobalMemoryStatus Lib "kernel32" ( _ lpBuffer As MEMORYSTATUS) Private Type MEMORYSTATUS dwLength As Long ' Gesamtlänge der Struktur dwMemoryLoad As Long ' Prozent des belegten Speichers dwTotalPhys As Long ' Gesamtarbeitsspeicher dwAvailPhys As Long ' Verfügbarer Arbeitsspeicher dwTotalPageFile As Long ' Größe der Auslagerungsdatei dwAvailPageFile As Long ' Verfügbarer Arbeitsspeicher dwTotalVirtual As Long ' Größe d. virtuellen Speichers dwAvailVirtual As Long ' Verfügbarer virtueller Speicher End Type Private lpInfo As MEMORYSTATUS Private Sub Form_Load() Me.Caption = "Speicher freigeräumt !" ' Timer auf 1 Sek. einstellen Timer1.Interval = 1000 End Sub Private Sub Timer1_Timer() Dim NeuPhys As Long Dim Phys As Long If InStr(Me.Caption, "freigeräumt") <> 0 Then Call GlobalMemoryStatus(lpInfo) NeuPhys = lpInfo.dwAvailPhys Phys = lpInfo.dwTotalPhys Label2 = "Freier Speicher nachher: " + _ CStr(NeuPhys / 1024) + " KB" 'Aktualisieren ' Ergänzung : Aufruf automatisieren wenn Speicher ' unter 20 MB If NeuPhys < 20000000 Then Command1 = True End If End If End Sub Private Sub Command1_Click() Dim Phys As Long Dim NeuPhys As Long Dim frei As Long Call GlobalMemoryStatus(lpInfo) ' Nie mehr als 50% vom RAM freiräumen Phys = lpInfo.dwTotalPhys / 60 ' Wieviel ist gerade frei? frei = lpInfo.dwAvailPhys Screen.MousePointer = vbHourglass ProgressBar1.Max = 20 Label1.Caption = "Freier Speicher voher: " + _ CStr(frei / 1024) + " KB" ReDim at(20) As String Dim i As Integer For i = 0 To 20 Me.ProgressBar1.Value = i at(i) = Space$(Phys) ' Speicher aufblähen DoEvents Me.Caption = "Räume Speicher frei.... [" & _ CStr(i / 20 * 100) & "%] Optimiert..." Next i Me.Caption = "Fertig" ProgressBar1.Value = 0 Me.Caption = "Speicher freigeräumt !" Screen.MousePointer = 0 End Sub Dieser Tipp wurde bereits 34.562 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats Juni 2024 Microsys Kramer Mausrad im Formular abschalten (Access) Deaktiviert das Mausrad in Access-Formularen. sevAniGif (VB/VBA) Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |