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 05-02-2003, 21:03   #1
Mezzetti0903
Senior Member
 
Iscritto dal: Nov 2000
Messaggi: 279
Negare l'istanziazione!!

Negare l'istanziazione!! Preferibilmente in C#

Mi potete fare un esempio in qualsisasi linguaggio di come potrebbe essere possibile, se mai è possibile, negare l'instanziazione da costruttore?? ES(un po' cialtrone perchè lo faccio sul momento):

public class Servizi
public Servizi(string username,string password) {
if ((username=="CIAO") && (password=="CIAO")) {
// OK TUTTO A POSTO
}
else { // ANNULLA L'ISTANZA }
}
}
Ora.. potrei che ne so mettere una variabile "isaccessible" = false
che viene controllata da TUTTI i metodi e propietà prima che si eseguino ma..NON MI SEMBRA ELEGANTE
non mi sembra nè
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero
Mezzetti0903 è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 10:30   #2
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Re: Negare l'istanziazione!!

Quote:
Originally posted by "Mezzetti0903"

Negare l'istanziazione!! Preferibilmente in C#

Mi potete fare un esempio in qualsisasi linguaggio di come potrebbe essere possibile, se mai è possibile, negare l'instanziazione da costruttore?? ES(un po' cialtrone perchè lo faccio sul momento):

public class Servizi
public Servizi(string username,string password) {
if ((username=="CIAO") && (password=="CIAO")) {
// OK TUTTO A POSTO
}
else { // ANNULLA L'ISTANZA }
}
}
Ora.. potrei che ne so mettere una variabile "isaccessible" = false
che viene controllata da TUTTI i metodi e propietà prima che si eseguino ma..NON MI SEMBRA ELEGANTE
non mi sembra nè
Una soluzione potrebbe essere quella di gettare un'eccezione nel costruttore:
Codice:
public class Servizi
   public Servizi(string username,string password) {
         if ((username=="CIAO") && (password=="CIAO")) {
               // OK TUTTO A POSTO
         }
         else { 
		throw Error("blablalba");
	}
   }
nel codice poi faresti cosi'
Codice:
...
try {
	x = new Servizi("pinco","pallino");
} catch( Error e )
{
...
}
ovviamente al netto degli errori . Conosco poco il C# e quindi non so se supporta le eccezioni nel costruttore, devi comunque stare attento che non e' mai una bella cosa cominciare un lavoro (costruire un oggetto) e poi lasciarlo a meta' (lanciando l'eccezione). Prima di lanciare l'eccezione provvedi a "ripulire" quanto fatto, ad esempio liberando risorse se queste non verranno sistemate automaticamente dal garbage-collector.
Una alternativa e' fare una classe apposita che costruisca (o meno) l'oggetto di cui hai bisogno:
Codice:
public class ServiceFactory
{
	public Servizi getService( string username, string password )
	{
		...
	}
}
che ritorna un oggetto se i parametri sono corretti, un null altrimenti. La cosa si puo' anche estendere: in questo caso infatti il vero oggetto ritornato non e' noto, potrebbe essere una sottoclasse di Servizi, e si potrebbe ritornare un oggetto con diritti particolari in base all'utente.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 11:00   #3
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Re: Negare l'istanziazione!!

non conosco C#, ma in Java puoi farlo creando SOLO un costruttore senza argomenti e dichiarandolo private.
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 11:55   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Vuoi che ci sia una sola istanza di quella classe in memoria ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 12:19   #5
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
In java esiste la classe IllegalArgumentException()...come ti hanno suggerito puoi lanciare un eccezione, ma non generica!

throw new IllegalArgumentException("tuo messaggio");

is very elegant
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 12:33   #6
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originally posted by "cn73"

In java esiste la classe IllegalArgumentException()...come ti hanno suggerito puoi lanciare un eccezione, ma non generica!

throw new IllegalArgumentException("tuo messaggio");

is very elegant



son punti di vista ma per me lanciare sempre un'eccezione in un costruttore per non fare istanziare un oggetto e' dal punto di vista del design e' orrido, non elegante.

Un'eccezione (come dice il nome) serve a notificare al chiamante che si e' verificato un problema (infrastruturale, NON applicativo) su una chiamata. E' l'intefaccia che fornisci che deve condizionare la chiamata, non un'eccezione!
Se vuoi condizionare l'istanziazione di un oggetto esiste un patter chiamato factory (con decine di varianti) che fa al caso tuo.

tutto IMHO, naturalmente ig:
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 12:34   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Se io la facessi in C++ farei così...ma funziona grazie ai puntatori...
Codice:
class Servizi {
   Servizi() { /*costruttore di default*/ }; //privato, non richiamabile direttamente
public:
   static Servizi* Autentifica(string user, string pass); //deve essere static
};

Servizi* Servizi::Autentifica(string user, string pass)
{
   if(user == "ciao" && pass == "ciao")
      return new Servizi;
   else
      return NULL;
}

//Si usa in questo modo:

Servizi *s = Servizi::Autentifica("pippo", "pluto");
if(s)
  //allocato
else
  //non allocato
Questo metodo è derivato abbastanza direttamente dal design-pattern "Singleton"....

http://www.devhood.com/tutorials/tutorial_details.aspx?tutorial_id=486
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 13:05   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Aggiungo che anche secondo me usare un'eccezione è come ammazzare una mosca con una cannonata...senza contare che è stilisticamente brutto...ma brutto brutto brutto...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 13:56   #9
Mezzetti0903
Senior Member
 
Iscritto dal: Nov 2000
Messaggi: 279
Re: Negare l'istanziazione!!

Innanzi tutto Grazie a tutti....
L'idea di lanciare l'eccezione è funzionale ma certo.. come dice Cionci... brutta brutta brutta....
Ecco invece è una buona idea l'ultima di /\/\@®¢Ø.... penso che farò così!!

Quote:
Originally posted by "/\/\@®¢Ø"



Una alternativa e' fare una classe apposita che costruisca (o meno) l'oggetto di cui hai bisogno:
Codice:
public class ServiceFactory
{
	public Servizi getService( string username, string password )
	{
		...
	}
}
che ritorna un oggetto se i parametri sono corretti, un null altrimenti. La cosa si puo' anche estendere: in questo caso infatti il vero oggetto ritornato non e' noto, potrebbe essere una sottoclasse di Servizi, e si potrebbe ritornare un oggetto con diritti particolari in base all'utente.
Grazie a tutti ancora
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero
Mezzetti0903 è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 14:08   #10
Tassadar
Senior Member
 
L'Avatar di Tassadar
 
Iscritto dal: Oct 2001
Città: Scorzè (VE)
Messaggi: 853
puoi anche, come diceva kingv, usare un metodo statico per avere l'istanza della classe che ti interessa e dichiarare il costruttore privato:

Codice:
public class Servizi{
  private Servizi(){
    super(); //costruttore ereditato da Object
  }

  public static Servizi getServizi(string username,string password) {
    if ((username=="CIAO") && (password=="CIAO")) {
      return new Servizi();
    }
    else {
      return null; //oppure throw new IllegalArgumentException("blah blah blah");
    }
  }
}
__________________
Mr. T.
Tassadar è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 14:21   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originally posted by "Tassadar"

puoi anche, come diceva kingv, usare un metodo statico per avere l'istanza della classe che ti interessa e dichiarare il costruttore privato:

Codice:
public class Servizi{
  private Servizi(){
    super(); //costruttore ereditato da Object
  }

  public static Servizi getServizi(string username,string password) {
    if ((username=="CIAO") && (password=="CIAO")) {
      return new Servizi();
    }
    else {
      return null; //oppure throw new IllegalArgumentException("blah blah blah");
    }
  }
}
Che è la stessa cosa di quelo che io ho fatto in C++...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 14:29   #12
Tassadar
Senior Member
 
L'Avatar di Tassadar
 
Iscritto dal: Oct 2001
Città: Scorzè (VE)
Messaggi: 853
esatto
Ciao defender
__________________
Mr. T.
Tassadar è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 14:30   #13
Mezzetti0903
Senior Member
 
Iscritto dal: Nov 2000
Messaggi: 279
!!

..anche :-))

Forse è anzi più chiaro e razionale con il metodo statico...

Grazie ancora :-D
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero
Mezzetti0903 è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 14:31   #14
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originally posted by "kingv"


Un'eccezione (come dice il nome) serve a notificare al chiamante che si e' verificato un problema (infrastruturale, NON applicativo) su una chiamata.
Ma questo non ha a che fare col fatto che sia gettata in un costruttore o in un metodo.
Oltretutto l'eccezione (come dice il nome ) e' semplicemente qualcosa che accade non troppo spesso, e che quindi e' scomodo dover gestire singolarmente, oppure quando avviene non si hanno informazioni sul come comportarsi. Nel caso in oggetto serve poco perche' presumibilmente il login avviene in un solo punto e quindi ha poco senso sostituire un controllo if con un try{...}catch nello stesso punto. Se pero' l'eccezione rientra in una categoria piu' generica di eccezioni si puo' comunque utilizzarla, raccogliendola molto piu' a monte per fare un repulisti con la ramazza e chiudere il tutto il contesto in cui ci si trova (che non e' necessariamente l'applicazione intera).

Quote:
E' l'intefaccia che fornisci che deve condizionare la chiamata, non un'eccezione!
Non sono d'accordo. Dipende dallo "schema generale", visto anche che l'eccezione serve appunto per spostarsi dal contesto locale.
Quote:
Se vuoi condizionare l'istanziazione di un oggetto esiste un patter chiamato factory (con decine di varianti) che fa al caso tuo.
Che e' il secondo esempio che ho fatto
Comunque non e' necessariamente detto che le factory siano la cosa migliore, perlomeno se il solo scopo e' controllare i parametri. In fondo un wrapper attorno al costruttore non e' poi molto differente da un try-catch , e scrivi pure piu' codice.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 15:33   #15
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originally posted by "/\/\@®¢Ø"


Ma questo non ha a che fare col fatto che sia gettata in un costruttore o in un metodo.
Oltretutto l'eccezione (come dice il nome ) e' semplicemente qualcosa che accade non troppo spesso, e che quindi e' scomodo dover gestire singolarmente, oppure quando avviene non si hanno informazioni sul come comportarsi. Nel caso in oggetto serve poco perche' presumibilmente il login avviene in un solo punto e quindi ha poco senso sostituire un controllo if con un try{...}catch nello stesso punto. Se pero' l'eccezione rientra in una categoria piu' generica di eccezioni si puo' comunque utilizzarla, raccogliendola molto piu' a monte per fare un repulisti con la ramazza e chiudere il tutto il contesto in cui ci si trova (che non e' necessariamente l'applicazione intera).
piu' che un qualcosa che accade raramente l'eccezione dovrebbe essere qualcosa che NON dovrebbe accadere in situazioni standard.
mettiamo che tu abbia un'applicazione che controlla il saldo di conto corrente perche' deve fare un bonifico. Se la comunicazione appc (o qualsiasi altra cosa usi per collegarti ad host) crasha ( fortuna che non faccio il prof di italiano) allora il lancio di una eccezione ad hoc puo' essere giustificato, in modo che nella catena dele chiamate si possa far pulizia e poi abortire la transazione. ma se ti viene risposto che il saldo di cc e' negativo (e quindi il bonifico non lo puoi fare) lanciare una NoTieneDineroException ( ) e' una ca**ata dal punto di vista del design, perche' questa e' una condizione applicativa che sara' anche rara ma deve essere gestita dal flusso del'applicazione, non deve stravolgerlo.






Quote:
Originally posted by "/\/\@®¢Ø"



Non sono d'accordo. Dipende dallo "schema generale", visto anche che l'eccezione serve appunto per spostarsi dal contesto locale.

come sopra, perche' lanciare un'eccezione quando puoi scrivere "return false"?


Quote:
Originally posted by "/\/\@®¢Ø"



Che e' il secondo esempio che ho fatto
Comunque non e' necessariamente detto che le factory siano la cosa migliore, perlomeno se il solo scopo e' controllare i parametri. In fondo un wrapper attorno al costruttore non e' poi molto differente da un try-catch , e scrivi pure piu' codice.
a me il problema non sembrava controllare i parametri (anche nel costruttore puoi farlo, non occorre una factory) ma impedire (o limitare) l'istanziazione di un oggetto :o
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 16:14   #16
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
Lanciare un'eccezione non è affatto brutto, brutto, brutto, brutto... ne tantomeno poco "stilistico". Esiste fior di letterautura su come creare classi di eccezione ad arte per adattarsi agli scopi funzionali.

Allora tanto vale per risolvere il problema del nostro amico controllare a priori, prima di istanziare l'oggetto, che i parametri siano accettabili.

Naturalmente IMHO
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 16:32   #17
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originally posted by "kingv"


piu' che un qualcosa che accade raramente l'eccezione dovrebbe essere qualcosa che NON dovrebbe accadere in situazioni standard.
Mi sa che intendiamo la stessa cosa .
Come dicevo sompra l'eccezione e' comoda e giustificata se posso lanciarla in molte parti e raccoglierla in una ( o poche ) cosi' che il codice "in mezzo" puo' fregarsene, a vantaggio della leggibilita'. Un esempio e' quello che fai tu, ma non e' comunque un concetto piu' generale

Quote:
come sopra, perche' lanciare un'eccezione quando puoi scrivere "return false"?
Il problema non e' il codice che si deve scrivere per segnalare un errore, ma quello per trattarlo ! Se poi devo scrivere cinquanta volte
if ( x != null ){ ... } else { ... } l'eccezione puo' essere una buona soluzione, perlomeno se mi e' permesso gestirla "non in loco" ( ovvero sostituire i suddetti if con altrettanti blocchi "try" non e' la soluzione che propongo io )

Quote:
a me il problema non sembrava controllare i parametri (anche nel costruttore puoi farlo, non occorre una factory) ma impedire (o limitare) l'istanziazione di un oggetto :o
Mi sono espresso male comunque la sostanza del mio discorso resta invariata
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 17:03   #18
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
Quote:
Originally posted by "/\/\@®¢Ø"



8< 8< 8< 8<

Mi sono espresso male comunque la sostanza del mio discorso resta invariata

ho riletto il primo post di Mezzetti, sono io che non ho capito 'na ma**a, non avevo letto il codice :o :o :o



comunque la sostanza del mio discorso resta invariata ig:
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 06-02-2003, 17:39   #19
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originally posted by "cn73"

Lanciare un'eccezione non è affatto brutto, brutto, brutto, brutto... ne tantomeno poco "stilistico". Esiste fior di letterautura su come creare classi di eccezione ad arte per adattarsi agli scopi funzionali.
Non è il fatto di crearsi classi di eccezione che non deve essere fatto, ma usare l'eccezione per riportare un evento che può essere tranquillamente gestito a livello di codice normale...
Sono d'accordo con kingv...l'eccezione deve essere qualcosa che deve rispecchiare un'anomalia nell'esecuzione del flusso abituale del programma... Un'autentificazione non riuscita non mi sembra affatto un fatto anomalo...
Quote:
Originally posted by "cn73"

Allora tanto vale per risolvere il problema del nostro amico controllare a priori, prima di istanziare l'oggetto, che i parametri siano accettabili.
Infatti è ciò che viene fatto con il metodo static... Il controllo viene effettuato prima di istanziare l'oggetto...
Perchè non faro al di fuori dell'oggetto ? Beh...dipende dal contesto... Se l'autentificazione è logicamente parte integrante dell'oggetto (ad esempio mettiamo che sia una classe di interfacciamento con un DB e che l'autentificazione sia in questo caso la connessione al DB) allora mi sembra logico che il metodo da adottare sia quello postato (soprattutto per poter riusare al meglio la classe)...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 07-02-2003, 00:38   #20
dm69
Senior Member
 
Iscritto dal: Dec 2001
Messaggi: 428
Secondo me le eccezioni dovrebbero essere usate sempre per gestire qualunque situazione non nominale.
Nel caso in questione si chiedeva di negare la creazione di un oggetto qualora non fossero verificate certe condizioni. Se il costruttore lanciasse una eccezione, il ramo di codice che doveva usare l'eventuale oggetto viene terminato senza dover fare alcun check del tipo:
if (p!=NULL)
....
else
...

In programmi di grande dimensione si risparmia una gran quantita' di codice di error handling. Inoltre, spesso, ci si dimentica di fare questo tipo di check e a run time possiamo avere dei crash inattesi.
In questo caso (se si usasse il C++), inoltre, usando l'eccezione possiamo anche evitare l'allocazione dinamica dell'oggetto (che spesso ci si dimentica di deallocare). Infatti non essendo abbligati a tornare un NULL per dire che la creazione e' fallita, possiamo usare l'oggetto come un tipo qualunque:

....
Servizi servizio(user, passwd);
.... // qui' ci arriviamo sole se il check e' superato.


Ciao a tutti.
__________________
PC: Phenom 2 955, 4 GB RAM DDR3, 2 x ATI HD 7870 Ghz edition
dm69 è 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 ...
Alcuni rivenditori giapponesi bloccano l...
Le feste non placano Amazon, anzi: aggio...
Roborock Q10 S5+ a un super prezzo: robo...
Formula sceglie WINDTRE BUSINESS per gar...
EXPO 1.20: AMD migliora il supporto all'...
MacBook Pro con chip M4, 24GB di RAM e 1...
Lefant M330 da 6.000Pa a 139€ o ECOVACS ...
Tornano gli sconti anche sulle scope ele...
Le scope elettriche Dreame H12, H14 e H1...
Il nucleo della cometa interstellare 3I/...
La Russia potrebbe sviluppare un'arma pe...
Manda la RAM Corsair in assistenza, rice...
ASUS ROG G1000 con 'AniMe Holo': saranno...
Un test di longevità ha messo alla prova...
Incat inizia i test dell'incredibile tra...
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: 11:30.


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