* * * *

Privacy Policy

Blog italiano

Clicca qui se vuoi andare al blog italiano su Lazarus e il pascal.

Forum ufficiale

Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il
Forum ufficiale di Lazarus in lingua inglese.

Lazarus 1.0

Trascinare un file nel programma
DB concetti fondamentali e ZeosLib
Recuperare codice HTML da pagina web
Mandare mail con Lazarus
Stabilire il sistema operativo
Esempio lista in pascal
File INI
Codice di attivazione
Realizzare programmi multilingua
Lavorare con le directory
Utilizzare Unità esterne
TTreeView
TTreeview e Menu
Generare controlli RUN-TIME
LazReport, PDF ed immagini
Intercettare tasti premuti
Ampliare Lazarus
Lazarus e la crittografia
System Tray con Lazarus
UIB: Unified Interbase
Il file: questo sconosciuto
Conferma di chiusura di un applicazione
Liste e puntatori
Overload di funzioni
Funzioni a parametri variabili
Proprietà
Conversione numerica
TImage su Form e Panel
Indy gestiore server FTP lato Client
PopUpMenu sotto Pulsante (TSpeedButton)
Direttiva $macro
Toolbar
Evidenziare voci TreeView
Visualizzare un file Html esterno
StatusBar - aggirare l'errore variabile duplicata
Da DataSource a Excel
Le permutazioni
Brute force
Indy 10 - Invio email con allegati
La gestione degli errori in Lazarus
Pascal Script
Linux + Zeos + Firebird
Dataset virtuale
Overload di operatori
Lavorare con file in formato JSON con Lazarus
Zeos ... dietro le quinte (prima parte)
Disporre le finestre in un blocco unico (come Delphi)
Aspetto retrò (Cmd Line)
Lazarus 1.0
Come interfacciare periferica twain
Ubuntu - aggiornare free pascal e lazarus
fpcup: installazioni parallele di lazarus e fpc
Free Pascal e Lazarus sul Raspberry Pi
Cifratura: breve guida all'uso dell'algoritmo BlowFish con lazarus e free pascal.
Creare un server multithread
guida all'installazione di fpc trunk da subversion in linux gentoo
Indice
DB concetti fondamentali e connessioni standard
Advanced Record Syntax
DB concetti fondamentali e DBGrid
DB concetti fondamentali e TDBEdit, TDBMemo e TDBText
Advanced Record Syntax: un esempio pratico
Superclasse form base per programmi gestionali (e non)
Superclasse form base per programmi gestionali (e non) #2 - log, exception call stack, application toolbox
Superclasse form base per programmi gestionali (e non) #3 - traduzione delle form
Superclasse form base per programmi gestionali (e non) #4 - wait animation
Un dialog per la connessione al database:TfmSimpleDbConnectionDialog
Installare lazarus su mac osx sierra
immagine docker per lavorare con lazarus e free pascal
TDD o Test-Driven Development
Benvenuto! Effettua l'accesso oppure registrati.
Novembre 23, 2024, 05:53:53 am

Inserisci il nome utente, la password e la durata della sessione.

102 Visitatori, 0 Utenti

Autore Topic: [Risolto] Estrazione exception backlog lentissima con fpc 3.2.2  (Letto 2363 volte)

Mimmo

  • Jr. Member
  • **
  • Post: 84
  • Karma: +3/-0
[Risolto] Estrazione exception backlog lentissima con fpc 3.2.2
« il: Gennaio 10, 2022, 04:53:41 pm »
Ciao,
stavo facendo un po' di test con la nuova versione di Lazarus 2.2 appena rilasciata e mi sono accorto che la procedura di estrazione dello stack trace in caso di eccezione è diventata lentissima rispetto a fpc 3.0.4. Si conclude con successo ma i tempi si sono decuplicati.
Io uso un po' di codice per scrivere il tracelog ed ottenere un report che scimmiotta un po' EurekaLog ma alla fine sono solo un po' di fiocchetti intorno al codice che è descritto qui https://wiki.freepascal.org/Logging_exceptions.
Qualcuno ha avuto il medesimo problema?
Grazie,
Mimmo
« Ultima modifica: Gennaio 12, 2022, 09:39:34 am da Mimmo »

nomorelogic

  • Global Moderator
  • Hero Member
  • *****
  • Post: 2921
  • Karma: +20/-4
Re:Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #1 il: Gennaio 10, 2022, 05:19:27 pm »
come debugger usi gdb o quello nuovo FpDebugger?

se è una installazione ex-novo può darsi sia FpDebugger ed in questo caso potresti rimettere gdb per vedere se i tempi tornano quelli di prima
Imagination is more important than knowledge (A.Einstein)

Mimmo

  • Jr. Member
  • **
  • Post: 84
  • Karma: +3/-0
Re:Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #2 il: Gennaio 10, 2022, 06:14:50 pm »
Ho provato con entrambi ma non cambia nulla.
Stesso risultato utilizzando i diversi livelli di ottimizzazione.
Anche passando da dwarf2 a "dwarf2 con i set" e a dwarf3 la situazione non è migliorata (ho solo notato che con fpDebugger e dwarf3 i nomi delle chiamate nel tracelog rispettano il case originale invece di essere tutte in maiuscolo).
Non ho cronometrato il tutto ma è evidente che con qualsiasi combinazione è molto più lento rispetto a fpc 3.0.4. Non so sotto Linux, per ora ho provato solo su windows.
Nel dettaglio, è l'esecuzione di BackTraceStrFunc che è diventata molto più lenta:

Codice: [Seleziona]
      Result := BackTraceStrFunc(ExceptAddr);
      Frames := ExceptFrames;
      for i := 0 to ExceptFrameCount - 1 do
        Result := Result + sLineBreak + BackTraceStrFunc(Frames[i]);

E altra cosa strana: se rieseguo il codice con l'errore che scatena il tracelog, la procedura diventa un fulmine. E' come se alla prima esecuzione venisse creata qualche struttura dati di appoggio con grande dispendio di risorse che poi viene però conservata in qualche cache per poter essere riutilizzata.
Son solo speculazioni le mie ovviamente... ancora brancolo.

Mimmo

  • Jr. Member
  • **
  • Post: 84
  • Karma: +3/-0
Re:Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #3 il: Gennaio 10, 2022, 06:18:04 pm »
Aggiungo un'altra cosa: sto provando il tutto con un eseguibile un po' ciccione, son 310 mega di file exe. Domani proverò con qualcosa di più snello per vedere se la lentezza è legata alla dimensione del programma.

Mimmo

  • Jr. Member
  • **
  • Post: 84
  • Karma: +3/-0
Re:Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #4 il: Gennaio 12, 2022, 09:36:04 am »
Aggiungo 2 righe giusto per tenerne traccia anche qui.
Ho postato il problema anche sul forum internazionale https://forum.lazarus.freepascal.org/index.php/topic,57840.msg430413.html#msg430413.
Alla fine è il backtrace che è diventato lento e così rimarrà, il meccanismo comunque continua a  funzionare.
Lo stesso eseguibile ciccione che ho usato sotto windows, l'ho ricompilato su linux e li' problemi di lentezza non ne ho rilevati. Quindi è qualcosa di specifico di win64.
Me lo terrò cosi', aggiungendo un bel cursore a clessidra nelle applicazioni gui a cavallo della procedura di logging (normalmente presento un report all'utente che poi può essere inviato via mail con un click). D'altronde è in questa release che è stato aggiunto Screen.StartWaitCursor...

DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1396
  • Karma: +44/-0
  • Prima ascoltare, poi decidere
Re:[Risolto] Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #5 il: Gennaio 12, 2022, 11:14:45 am »
Scusa se replico a d un post [RISOLTO] ma sono curioso: cosa ti porta ad attivare nella versione compilata di release il "backtrace" ?

Normalmente tali funzionalità vengono sfruttate solo in fase di sviluppo, test di qualità o altro ma non con il prodotto "release".

In genere le applicazioni, appunto dopo una fase di test (chiamiamolo debug o altro), sviluppano un loro log, ma puntuale con il dato / dati essenziali per una analisi (molto spesso ricavati da un try ... except) legati ad anomalie non gestite (o gestite ma che devono essere segnalate).

Stò pensando alle mie applicazioni e se dovessi attivare un backtrace, sarebbe improbabile che possa essere attuato ... ho una stack normalmente occupato con un "sacco" di dati (record ad esempio), e un "sacco" di Thread.

Ciao 
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

Mimmo

  • Jr. Member
  • **
  • Post: 84
  • Karma: +3/-0
Re:[Risolto] Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #6 il: Gennaio 13, 2022, 03:31:04 pm »
Scusa se replico a d un post [RISOLTO] ma sono curioso: cosa ti porta ad attivare nella versione compilata di release il "backtrace" ?
[...]

Ciao,
nei rilasci ormai d'ufficio mantengo sempre in piedi un meccanismo  "alla eurekalog" perchè mi permette di gestire la manutenzione dei programmi con una efficacia altrimenti impensabile. Non è un log esteso ma solo un modo differente di gestire le eccezioni.
Alla fine la cosa si paga in termini di un eseguibile di taglia extra-large (opzione -gl abilitata in release) ma al giorno d'oggi non è più un problema (almeno nei contesti in cui opero io...) e in ogni caso i benefici ripagano ampiamente.
Nella pratica, quando viene sollevata una eccezione, all'utente compare una finestra come quella visibile nel primo allegato. Da quella l'utente può spedire una mail con un report simile a quello che vedi nel secondo allegato.
Per anni in azienda abbiamo usato Eurekalog con Delphi con grandi benefici. Di notevole c'è che in Lazarus + fpc si riesca a mettere in piedi lo stesso meccanismo ma a costo zero..



DragoRosso

  • Scrittore
  • Hero Member
  • *****
  • Post: 1396
  • Karma: +44/-0
  • Prima ascoltare, poi decidere
Re:[Risolto] Estrazione exception backlog lentissima con fpc 3.2.2
« Risposta #7 il: Gennaio 13, 2022, 04:42:23 pm »
Grazie per la cortesia della risposta :)

Alla prossima, ciao.
:) Ogni alba è un regalo, ogni tramonto è una conquista :)

 

Recenti

How To

Utenti
  • Utenti in totale: 803
  • Latest: maXim.FI
Stats
  • Post in totale: 19170
  • Topic in totale: 2287
  • Online Today: 100
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 0
Guests: 102
Total: 102

Disclaimer:

Questo blog non rappresenta una testata giornalistica poiché viene aggiornato senza alcuna periodicità. Non può pertanto considerarsi un prodotto editoriale ai sensi della legge n. 62/2001.