Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-06-2010, 12:06   #1
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
[c++] Dll per Excel, eccessivo utilizzo di memoria

Ciao a tutti,
ho un problema con una DLL scritta in C++ per Excel. Tale dll viene richiamata in un ciclo for, quindi eseguita alcune migliaia di volte. Osservando l'occupazione di memoria dal Task Manager ho notato che la memoria utilizzata da excel cresce continuamente fino raggiungere il massimo disponibile provocando il crash dell'excel.
Con altre dll scritte in fortran il problema non si presenta, però visto che la dll è parecchio lunga, non ho al momento intenzione di tradurla in fortran.
Nel codice ho avuto cura di deallocare gli array creati dinamicamente e mettere a NULL i puntatori.
Mi potete suggerire una strada per ovviare a questo problema?
Grazie mille!
Buona giornata...
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:32   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Se ritieni che il tuo codice non sia responsabile dei leak evidentemente è la libreria. Probabilmente tutte le volte che richiami quel metodo particolare esegue delle allocazioni che o non vengono deallocate prima della fine del metodo oppure richiedono una chiamata esplicita ad altro metodo per essere deallocate.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:44   #3
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
Mi sembra che sia a libreria la responsabile dei leaks, perchè se eseguo il codice commentando la chiamata alla dll, non ho problemi con la memoria.
Per deallocare i vettori che ho usato nel codice c++, ho usato "delete [] array" e poi "array=NULL". Ci sono altri modi per deallocare gli array?

Ecco, un altro problema che nasce nel richiamare la dll da vba...Se richiamo la dll da excel, ottengo un errore di overflow al termine della chiamata a meno di non mettere delle istruzioni intermedie che prendano tempo. Sono forse collegati i due problemi?

Grazie di nuovo!
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 12:53   #4
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
se allo scaricamento della DLL (notifica DLL_PROCESS_DETACH, oppure nel codice del distruttore di una variabile globale) invochi la funzione _CrtDumpMemoryLeaks viene inviato al debugger un dump dei blocchi di memoria allocati con new e non ancora deallocati.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 13:12   #5
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
Ho provato ad invocare la funzione _CrtDumpMemoryLeaks, ma non ottengo nessun errore: tutto sembra deallocato a dovere. Non è che è l'excel a continuare a riempire la memoria a questo punto?
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 16:20   #6
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da Kesslers Guarda i messaggi
Ho provato ad invocare la funzione _CrtDumpMemoryLeaks, ma non ottengo nessun errore: tutto sembra deallocato a dovere. Non è che è l'excel a continuare a riempire la memoria a questo punto?
sicuro di averla invocata nel punto giusto?
inoltre puoi incollare qui il contenuto della Output Window di Visual Studio? ora non ricordo con certezza ma mi pare che la _CrtDumpMemoryLeaks non lasciasse mai "a mani vuote", se non c'era nessun leak un messaggio di successo te lo dava. mi pare.

ad ogni modo non é escluso che la colpa possa essere o di Excel o di qualche altro componente, per esempio il motore di parsing di VBScript utilizzato da Excel per far girare gli script in VBA. in questo caso peró non saprei aiutarti purtroppo, servirebbe qualche tool che ti faccia almeno capire da quale heap proviene il leak; tools del genere possono essere realizzati tramite apposite chiamate Win32 ma molto probabilmente ne esistono di giá fatti che io non conosco.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2010, 17:14   #7
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
Io l'ho messa al termine del programma dopo aver deallocato tutti i vettori dinamici ed i puntatori.
Stando alla guida in linea la funzione restituisce True se si verificano errori, altrimenti restituisce False...
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 11:26   #8
Andy1984
Member
 
L'Avatar di Andy1984
 
Iscritto dal: Mar 2010
Città: Roma
Messaggi: 132
Utilizza l'interop della microsoft è una bomba non da nessun problema ed è veloce!
Andy1984 è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 12:05   #9
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Andy1984 Guarda i messaggi
Utilizza l'interop della microsoft è una bomba non da nessun problema ed è veloce!
Peccato che non sia C++
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 12:45   #10
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
Non è disponibile, lavoro su un computer aziendale...
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 14:08   #11
Andy1984
Member
 
L'Avatar di Andy1984
 
Iscritto dal: Mar 2010
Città: Roma
Messaggi: 132
Come non è C++?? C++/cli.

Che vorresti dire che usi il pc aziendale, l'interop è scaricabile da internet...
Andy1984 è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 14:17   #12
Kesslers
Member
 
Iscritto dal: Feb 2010
Messaggi: 35
Intendo dire che non posso aggiungere altri programmi a mio piacimento.
Kesslers è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 17:08   #13
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Andy1984 Guarda i messaggi
Come non è C++?? C++/cli.
Che non è C++.
Il C++ è uno standard ISO, C++/CLI è un linguaggio della galassia .NET
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 22-06-2010, 22:27   #14
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Che non è C++.
Il C++ è uno standard ISO, C++/CLI è un linguaggio della galassia .NET
be', é uno standard ECMA
comunque sono d'accordo, C++ e C++/CLI sono due linguaggi diversi, hanno solo delle somiglianze nella sintassi.
fero86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Il dodicesimo lancio del razzo spaziale ...
Blue Origin sta assemblando il secondo l...
Meta moltiplica gli investimenti in data...
Addio riflessi fastidiosi? Samsung prese...
PlayStation 5, doccia fredda da Sony: i ...
Super Meat Boy 3D: annunciata la data d'...
XT View Matrix, il mid-tower Phanteks ch...
David Sacks lascia il ruolo di 'Crypto C...
LG All Stars 2026: quando l'installatore...
Addio ad Anna's Archive? Ecco la mossa l...
Addio al Mac Pro, Apple mette fine a un ...
Panasonic a MCE 2026: la rivoluzione sil...
Netflix alza la posta: il piano Premium ...
Nimbus Innovation Awards – Cloud Edition...
Wikipedia vieta i contenuti generati dal...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 20:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v