2013-07-16 13 views
6

Delphi XE, Windows 7 64-bitDelphi perdita di memoria quando si aggiungono lingua

Quando si aggiunge il supporto di lingua per un'applicazione vuota riceverete una perdita di memoria (FastMM4).

Come riprodurre:

  • creare nuova VCL I moduli di domanda
  • modificare il .dpr e aggiungere ReportMemoryLeaksOnShutdown := True;
  • build/eseguire l'applicazione e chiudere l'applicazione -> perdite riportate
  • ora aggiungi una lingua (Progetto -> Lingue -> Aggiungi)
  • Costruisci/Esegui nuovamente e chiudi l'applicazione -> Perdita di memoria ??

FastMM4 piena di debug di report in modalità:

--------------------------------2013/7/16 14:54:34-------------------------------- 
A memory block has been leaked. The size is: 12 

This block was allocated by thread 0x17EC, and the stack trace (return addresses) at the time was: 
40455E 
40952D 
4094C8 
409834 
409941 
450058 
74548D76 [Unknown function at FirstHookFunc] 
7778FA1A [ZwOpenKey] 
75924033 [OpenRegKey] 
759240AE [OpenRegKey] 
777FA71A [Unknown function at RtlUlonglongByteSwap] 

The block is currently used for an object of class: Unknown 

The allocation number is: 6 

Current memory dump of 256 bytes starting at pointer address 7EF9A610: 
6E 00 6C 00 2D 00 42 00 45 00 00 00 41 58 0D 7A 00 00 00 00 C1 A6 F9 7E 00 00 00 00 00 00 00 00 
00 00 00 00 00 00 00 00 2E 00 00 00 5E 45 40 00 DD 99 40 00 6D 71 4B 00 98 65 40 00 04 66 40 00 
77 A6 40 00 98 7C 4B 00 AA 33 8D 76 F2 9E 7A 77 C5 9E 7A 77 00 00 00 00 EC 17 00 00 EC 17 00 00 
1F 9A 40 00 53 7F 42 00 2C 65 40 00 EA 68 40 00 E3 7C 4B 00 AA 33 8D 76 F2 9E 7A 77 C5 9E 7A 77 
00 00 00 00 00 00 00 00 00 00 00 00 08 00 00 00 00 00 00 00 B6 5C 27 4D 5C 12 4C 00 80 80 80 80 
49 A3 D8 B2 80 80 80 80 00 00 00 00 F9 B7 F9 7E 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 
65 00 00 00 5E 45 40 00 A7 50 40 00 22 56 40 00 DC 50 40 00 5F 72 4B 00 78 96 44 00 8E 72 4B 00 
98 65 40 00 04 66 40 00 77 A6 40 00 98 7C 4B 00 EC 17 00 00 EC 17 00 00 7A 45 40 00 C5 50 40 00 
n . l . - . B . E . . . A X . z . . . . Á ¦ ù ~ . . . . . . . . 
. . . . . . . . . . . .^E @ . Ý ™ @ . m q K . ˜ e @ . . f @ . 
w ¦ @ . ˜ | K . ª 3 v ò ž z w Å ž z w . . . . ì . . . ì . . . 
. š @ . S B . , e @ . ê h @ . ã | K . ª 3 v ò ž z w Å ž z w 
. . . . . . . . . . . . . . . . . . . . ¶ \ ' M \ . L . € € € € 
I £ Ø ² € € € € . . . . ù · ù ~ . . . . . . . . . . . . . . . . 
e . . .^E @ . § P @ . " V @ . Ü P @ . _ r K . x – D . Ž r K . 
˜ e @ . . f @ . w ¦ @ . ˜ | K . ì . . . ì . . . z E @ . Å P @ . 

--------------------------------2013/7/16 14:54:34-------------------------------- 
This application has leaked memory. The small block leaks are (excluding expected leaks registered by pointer): 

5 - 12 bytes: Unknown x 1 

Note: Memory leak detail is logged to a text file in the same folder as this application. To disable this memory leak check, undefine "EnableMemoryLeakReporting". 

Ora per la parte divertente: rimuovere la lingua ed eseguire nuovamente -> i soggiorni di perdita!

È possibile rimuovere la perdita eliminando tutti i file relativi al progetto (.dproj, .dproj2007, .dsk e così via ..) tranne i file .dpr e .res.

Qualcuno può spiegarmi cosa sta succedendo?

UPDATE

Utilizzando gli indirizzi dal registro dettaglio, sembra ho trovato la perdita nel System.Pas:

var 
    PreferredLanguagesOverride: PChar = nil; 

...  
procedure SetLocaleOverride(const NewPreferredLanguages: string); 
var 
    L: Integer; 
begin 
    if PreferredLanguagesOverride <> nil then 
    FreeMem(PreferredLanguagesOverride); 
    L := Length(NewPreferredLanguages); 
    if L > 0 then 
    begin 
    Inc(L); 
    GetMem(PreferredLanguagesOverride, L * SizeOf(Char)); 
    MoveChars(NewPreferredLanguages[1], PreferredLanguagesOverride^, L); 
    end; 
end; 

SetLocaleOverride si chiama e la memoria riserve per il PreferredLanguagesOverridePChar. Ho scansionato System.Pas per FreeMem(PreferredLanguagesOverride) ma questa è l'unica occorrenza!

UPDATE2

ho trovato il motivo per cui chiama Delphi la SetLocaleOverride di routine:

quando si aggiunge il supporto della lingua, una chiave di registro viene creato con il nome del percorso completo eseguibile e la localizzazione di sistema come valore: HKEY_CURRENT_USER \ Software \ Embarcadero \ Locales

L'eliminazione di questo tasto impedisce al delphi di chiamare la routine SetLocaleOverride.

Domanda:

  • qualcuno può verificare se questo problema esiste in versioni successive Delphi?(Oppure faccio un rapporto QC)

UPDATE 3

c'è già una QC report (105136) ed è stato fissato dal XE3

Domanda: Qualcuno mi può mostrare come questo è stato aggiornato in XE3?

+1

Invia un rapporto QC e chiama RegisterExpectedMemoryLeak. –

+0

Impossibile riprodurre in Delphi XE3, Windows 7 64-bit ... – TLama

+1

@Tlama: grazie, apparentemente è stato corretto nella tua versione :) – whosrdaddy

risposta

0

Come già indicato nella mia domanda, questo è stato risolto da XE3.

Per quelli con versioni inferiori, è possibile applicare patch a System.pas.

Aggiungere SetLocaleOverride(''); nel procedure _Halt0 appena prima della riga:

FinalizeUnits; 

Questo permetterà di eliminare la perdita di memoria.

Buono a sapersi: How to recompile System.pas.

Se non si desidera ricompilare System.pas, è possibile chiamare SetLocaleOverride(''); in una sezione finalization.