Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-02-2011, 16:13   #1
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
[c#] Gestione errori try-catch concorrenza file

Salve,
ho scritto un applicativo in c# su visual studio 2008.
Mi trovo a dover gestire una concorrenza su un file da cancellare che viene scritto da un'altra applicazione.
Ho inserito la file.delete all'interno del try e vorrei, semplicemente, che se non riesce a cancellarlo non ritorni nessun errore, perchè poi ci riproverà al successivo giro dell'applicazione. Adesso invece se trova il file occupato da un altro processo mi si blocca l'applicazione con l'errore che non ha potuto accedere al file.
Come devo gestirla?
Grazie!!!
Ciao!
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2011, 18:17   #2
s1m0_93
Bannato
 
Iscritto dal: Nov 2008
Messaggi: 136
Quote:
Originariamente inviato da k-it Guarda i messaggi
Salve,
ho scritto un applicativo in c# su visual studio 2008.
Mi trovo a dover gestire una concorrenza su un file da cancellare che viene scritto da un'altra applicazione.
Ho inserito la file.delete all'interno del try e vorrei, semplicemente, che se non riesce a cancellarlo non ritorni nessun errore, perchè poi ci riproverà al successivo giro dell'applicazione. Adesso invece se trova il file occupato da un altro processo mi si blocca l'applicazione con l'errore che non ha potuto accedere al file.
Come devo gestirla?
Grazie!!!
Ciao!
Penso che basti non scrivere nulla nel catch
Codice:
try
{

    //tentativo di eliminazione file

}
catch(Exception ex)
{
}
s1m0_93 è offline   Rispondi citando il messaggio o parte di esso
Old 12-02-2011, 19:28   #3
DarkSiDE
Senior Member
 
L'Avatar di DarkSiDE
 
Iscritto dal: Dec 2001
Città: Lecce
Messaggi: 3936
Quote:
Originariamente inviato da s1m0_93 Guarda i messaggi
Penso che basti non scrivere nulla nel catch
Codice:
try
{

    //tentativo di eliminazione file

}
catch(Exception ex)
{
}
vero
__________________
Non farò mai più affari con khalhell, 4HwGenXX.
DarkSiDE è offline   Rispondi citando il messaggio o parte di esso
Old 13-02-2011, 15:33   #4
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
Quote:
Originariamente inviato da DarkSiDE Guarda i messaggi
vero
Codice:
if (by_ing5.Length > 0 && by_ing6.Length > 0)
{
   try
   {
      File.Delete(@"Z:\TEMP\scatta_usc");
   }
   catch { }
}
avevo messo così, non avevo messo Exception ex, provo e vedo se va
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
Old 15-02-2011, 12:44   #5
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
Quote:
Originariamente inviato da k-it Guarda i messaggi
Codice:
if (by_ing5.Length > 0 && by_ing6.Length > 0)
{
   try
   {
      File.Delete(@"Z:\TEMP\scatta_usc");
   }
   catch { }
}
avevo messo così, non avevo messo Exception ex, provo e vedo se va
si pare che vada!
Grazie!
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2011, 17:07   #6
ziggy1979
Junior Member
 
L'Avatar di ziggy1979
 
Iscritto dal: Jan 2011
Messaggi: 8
Ciao a tutti,
ho letto quanto suggerito e concordo su quasi tutto.
Infatti stare in ascolto sulla exception è corretto ma io starei un po' meno generico.
Infatti:
1) starei solo in ascolto solo sulle eccezioni di tipo IOException
2) nel caso di eccezioni di tipo IOException inoltre andrei a vedere se l'eccezione era dovuta al fatto che il file è lokkato da altri processi e non per altri motivi
Ecco il mio codice


try
{
File.Delete(fileName);
}
catch (IOException ex)
{
if (IsFileLocked(ex))
{
//siamo d'accordo che non devi fare nulla
}
else
{
throw;
}
}

dove la procedura IsFileLocked è la seguente.

private static bool IsFileLocked(IOException exception)
{
int errorCode = Marshal.GetHRForException(exception) & ((1 << 16) - 1);
return errorCode == 32 || errorCode == 33;
}

Ziggy.
__________________
Ziggy
ziggy1979 è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2011, 10:13   #7
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
Quote:
Originariamente inviato da ziggy1979 Guarda i messaggi
Ciao a tutti,
ho letto quanto suggerito e concordo su quasi tutto.
Infatti stare in ascolto sulla exception è corretto ma io starei un po' meno generico.
Infatti:
1) starei solo in ascolto solo sulle eccezioni di tipo IOException
2) nel caso di eccezioni di tipo IOException inoltre andrei a vedere se l'eccezione era dovuta al fatto che il file è lokkato da altri processi e non per altri motivi
Ecco il mio codice


try
{
File.Delete(fileName);
}
catch (IOException ex)
{
if (IsFileLocked(ex))
{
//siamo d'accordo che non devi fare nulla
}
else
{
throw;
}
}

dove la procedura IsFileLocked è la seguente.

private static bool IsFileLocked(IOException exception)
{
int errorCode = Marshal.GetHRForException(exception) & ((1 << 16) - 1);
return errorCode == 32 || errorCode == 33;
}

Ziggy.
Ciao,
il delete e tutto il resto adesso sembra funzionare con try e cathc(IOException ex), il nuovo problema riguarda una dll che carico nell'onLoad del form,
il tutto funziona per un certo tempo quando dopo un po' di ore mi ritrovo che è andato in errore, dagli AppCrash che salva windows 7 sembra che sia la dll in questione ad andare in errore, ma non so come gestirla. Dovrei poter riavviare il programma in automatico quando si blocca ma non so se è possibile, anche perchè non mi ritorna un errore di una particolare funzione del mio programma ma sembra che sia la dll stessa ad andare in errore e non posso gestirla.
Bohhhh
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
Old 20-02-2011, 11:59   #8
ziggy1979
Junior Member
 
L'Avatar di ziggy1979
 
Iscritto dal: Jan 2011
Messaggi: 8
scusa ma non puoi semplicemente mettere le chiamate a questa dll sotto dei blocchi try catch?
così se la chiami e spacca, intercettando l'errore, non ti crassha la tu app.
oppure proverei a caricare e scaricare la dll prima e dopo l'utilizzo!
__________________
Ziggy
ziggy1979 è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2011, 09:36   #9
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
Quote:
Originariamente inviato da ziggy1979 Guarda i messaggi
scusa ma non puoi semplicemente mettere le chiamate a questa dll sotto dei blocchi try catch?
così se la chiami e spacca, intercettando l'errore, non ti crassha la tu app.
oppure proverei a caricare e scaricare la dll prima e dopo l'utilizzo!
Non la posso richiamare direttamente io ma io avvio solo l'istanza che poi richiama la dll quando gli occorre
Codice:
public void Form1_Load(object sender, EventArgs e)
        {
            
            //caricamento e avvio dell'applicazione Anpr all'apertura della finestra (Form1)
            AnprSupport.Instance.Open(Handle); //collegata al riferimento della finestra Handle
            AnprSupport.Instance.LoadConfiguration("anpr2test.ini"); //caricamento file configurazione
            AnprSupport.Instance.ReadReceived += ReadHandler; //collegamento alla funzione ReadHandler alla ricezione della lettura 
            AnprSupport.Instance.Start(); //avvio dell'applicazione
            System.Diagnostics.Process test = System.Diagnostics.Process.Start("C:\\Program Files\\etech\\setup_diatec\\Diatec1.exe","/MIN");
            Worker workerObject = new Worker();
            Thread workerThread = new Thread(workerObject.DoWork);
            workerThread.Start();
            
            
        }
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
Old 07-03-2011, 10:59   #10
k-it
Junior Member
 
Iscritto dal: Sep 2005
Messaggi: 20
solo la modifica della dll stessa ha risolto il problema
__________________
"Aspetto che il panico cresca, quando la paura si tramuta in visioni celestiali, inizio a staccare..." (Schwantz)
k-it è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
X lancia Creator Studio su mobile: nuovi...
Dieci anni fa SpaceX fece atterrare per ...
POCO M8 e M8 Pro arriveranno nel 2026: e...
Caos Formula 1: il motore Mercedes &egra...
Tariffe nazionali per le chiamate e gli ...
Tassa chilometrica non solo per elettric...
FSR 4 su Radeon RX 5000, 6000 e 7000? Li...
Quanti alberi ci sono in Skyrim? In The ...
Pocket Max, la nuova console Mangmi punt...
Pubblicato maxi backup di Spotify: 300 T...
GTA 6 potrebbe evolversi in un MMORPG, s...
Green Deal anche per i caldarrostai: a R...
BYD lancia la condivisione dei caricator...
L'Antitrust italiano colpisce Apple: san...
Lo Stato paga il conto: un miliardo di e...
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: 15:19.


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