Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS Expertbook PM3: il notebook robusto per le aziende
ASUS Expertbook PM3: il notebook robusto per le aziende
Pensato per le necessità del pubblico d'azienda, ASUS Expertbook PM3 abbina uno chassis particolrmente robusto ad un pannello da 16 pollici di diagonale che avantaggia la produttività personale. Sotto la scocca troviamo un processore AMD Ryzen AI 7 350, che grazie alla certificazione Copilot+ PC permette di sfruttare al meglio l'accelerazione degli ambiti di intelligenza artificiale
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo
Abbiamo provato per diversi giorni una new entry del mercato italiano, la Gowow Ori, una moto elettrica da off-road, omologata anche per la strada, che sfrutta una pendrive USB per cambiare radicalmente le sue prestazioni
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design
OnePlus 15 nasce per alzare l'asticella delle prestazioni e del gaming mobile. Ma non solo, visto che integra un display LTPO 1,5K a 165 Hz, OxygenOS 16 con funzioni AI integrate e un comparto foto con tre moduli da 50 MP al posteriore. La batteria da 7.300 mAh con SUPERVOOC 120 W e AIRVOOC 50 W è la ciliegina sulla torta per uno smartphone che promette di offrire un'esperienza d'uso senza alcun compromesso
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-11-2005, 19:29   #1
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
[CICLO 4] Test Driven Development task 4.2.2 (cdimauro vs 71104)

come al solito i commit saranno precari per un po'.

dunque, test list:
- test per coda vuota
- test per coda non vuota
- test per rimozione di un elemento dalla coda (anche più d'uno)
- test per ordine corretto degli elementi della coda (anche più d'uno)
- test per la correttezza del tipo di evento (pressione o rilascio)
- test per i timestamp
- varie ed eventuali...

allora, il test per la coda vuota è molto semplice:
Codice:
public void testQueueEmpty()
{
	assertTrue(input.isQueueEmpty());
}
che è talmente semplice che faccio anche quello per la coda non vuota
Codice:
public void testQueueNotEmpty()
{
	input.generateKey(KeyCode.vk_Left);
	assertFalse(input.isQueueEmpty());
}
cdimauro, questi due come li risolveresti?

Ultima modifica di 71104 : 10-11-2005 alle 20:20.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 20:09   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Per il primo test avrei risolto semplicemente aggiungendo il seguente codice alla classe input:

Codice:
    public boolean isQueueEmpty()
    {
      return true;
    }
Aggiungendo il secondo test, mi vedo costretto a introdurre la variabile d'istanza empty a Input e a modificare un costruttore un po' di methodi:

Codice:
    private boolean empty;

    private Input(AbstractKeyboard keyboard)
    {
        this.keyboard = keyboard;
        keys = new BitSet();
        empty = true;
    }

    public boolean isQueueEmpty()
    {
      return empty;
    }

    public void generateKey(KeyCode key)
    {
        keys.set(key.value(), true);
        empty = false;
    }
Il minimo indispensabile per far passare i test...

A te la palla Alberto.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys

Ultima modifica di cdimauro : 10-11-2005 alle 20:12.
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 20:19   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, a questo punto già mi rendo conto di aver dimenticato un'aspetto importante della gestione della coda: la rimozione di elementi. l'inserzione avviene quando vengono ricevuti eventi dalla tastiera, ma la rimozione? quindi siccome l'operazione di rimozione ci serve, aggiungo questo test:
Codice:
public void testQueueItemRemoval()
{
	input.generateKey(KeyCode.vk_Right);
	assertTrue(input.extractKey() == KeyCode.vk_Right);
}
l'operazione di peek casomai la aggiungeremo dopo (non è neanche detto che serva).

PS: ho editato il post iniziale

Ultima modifica di 71104 : 10-11-2005 alle 20:24.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 21:05   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Per far passare questo test introduco un'altra variabile, che mi serve per ricordare l'ultimo tasto "premuto", e aggiungo anche il metodo extractKey() :

Codice:
    private KeyCode lastKey;

    public void generateKey(KeyCode key)
    {
        keys.set(key.value(), true);
        empty = false;
        lastKey = key;
    }


    public KeyCode extractKey()
    {
        empty = true;
        return lastKey;
    }
A questo punto scrivo io il test per il punto seguente, che è:
" test per ordine corretto degli elementi della coda (anche più d'uno)".

Codice:
    public void testQueueSequenceOrder()
    {
      input.generateKey(KeyCode.vk_Right);
      input.generateKey(KeyCode.vk_Up);
      assertTrue(input.extractKey() == KeyCode.vk_Right);
      assertTrue(input.extractKey() == KeyCode.vk_Up);
    }
A te Alberto
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 21:05   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, scusate torno tra una mezz'ora, vado a cena ^^
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 21:09   #6
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
Posso muovere un dubbio ? Siamo sicuri che serva la rimozione degli eventi dalla coda ? Perchè invece non realizzate una coda circolare di N elementi...
Anche perchè...chi si mette a rimuovere gli eventi dalla coda ? Nel senso che gli utilizzatori di input non possono sapere se lo stesso input servirà anche ad altri quindi la politica di rimozione diverrebbe molto complessa...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 21:16   #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
Ah...muovete i test che state scrivendo in it.diamonds.tests.ignore altrimenti la build fallisce ed il repository non deve mai stare con la build rotta...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 22:02   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
allora, l'ultimo test di cdimauro introduce la triangolazione sul campo dell'ultimo tasto premuto, nel senso che potrei risolverlo aggiungendo un'altro membro analogo a lastKey, ma per triangolazione ne aggiungo un numero virtualmente illimitato creando la coda
per risolvere il test ho aggiunto un campo next a KeyCode (inizializzato a null) e ho modificato il codice di generateKey ed extractKey come segue:
Codice:
    public void generateKey(KeyCode key)
    {
        keys.set(key.value(), true);
        empty = false;
        if (null != queue)
        {
            queue.next = key;
        }
        else {
            queue = key;
        }
    }


    public KeyCode extractKey()
    {
        KeyCode result = queue;
        if (null != queue)
        {
            queue = queue.next;
            result.next = null;
        }
        empty = (null != queue);
        return result;
    }
(tra parentesi il campo lastKey è ora diventato queue, nome più significativo in questo caso).
cionci, la coda circolare è inutile da implementare, per noi sarebbe solo codice in più, potenzialmente sbagliato, e la rimozione serve per forza: la dovrà usare reactToInput per lavorare sugli input (senza contare che serve necessariamente per testare il corretto ordine degli elementi nella coda).

PS: ovviamente poi dopo aver sistemato reactToInput dovremo anche eliminare la gestione degli input tramite bitset, e questo sarà un refactoring che faremo alla fine.
dal momento che si tratta quasi esclusivamente di rimuovere codice, non sarà necessario usare altri test durante il refactoring, l'importante è controllare ad ogni piccolo cambiamento che i test attuali continuino a passare tutti.

Ultima modifica di 71104 : 10-11-2005 alle 22:08.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 22:24   #9
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da cionci
Posso muovere un dubbio ? Siamo sicuri che serva la rimozione degli eventi dalla coda ? Perchè invece non realizzate una coda circolare di N elementi...
Anche perchè...chi si mette a rimuovere gli eventi dalla coda ? Nel senso che gli utilizzatori di input non possono sapere se lo stesso input servirà anche ad altri quindi la politica di rimozione diverrebbe molto complessa...
L'input dovrebbe essere associato a un ben determinato oggetto, che lo "consumerà". E quindi non dovrebbe essere accessibile ad altri oggetti.

Per quanto riguarda la coda circolare, se c'è già una classe Java disponibile non c'è problema. Io non conosco la libreria di Java, quindi non so. Altrimenti è meglio prendere un Vector e implementare la coda in questo modo.

Il tutto IMHO, chiaramente.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys

Ultima modifica di cdimauro : 10-11-2005 alle 22:38.
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 22:27   #10
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ragazzi, tra imprevisti rotture di OO ed errori nostri nel codice questo task sta durando una vita!!!
allora, la mia implementazione dei nodi della queue non va bene, e per mettere in evidenza l'errore concettuale basta questo test:
Codice:
        input.generateKey(KeyCode.vk_Right);
        input.generateKey(KeyCode.vk_Up);
        input.generateKey(KeyCode.vk_Left);
        input.generateKey(KeyCode.vk_Up);
        assertTrue(input.extractKey() == KeyCode.vk_Right);
        assertTrue(input.extractKey() == KeyCode.vk_Up);
        assertTrue(input.extractKey() == KeyCode.vk_Left);
        assertTrue(input.extractKey() == KeyCode.vk_Up);
il problema è che il Java non gestisce le enum con istanze e puntatori come gli oggetti, cioè se io inserisco due volte un vk_Right io di fatto non ho inserito due oggetti diversi, ma ho inserito due volte la stessa enum, quindi il campo next di vk_Right all'ultima inserzione viene modificato in maniera errata.
ora stiamo cercando la soluzione: sarà necessario implementare la coda diversamente.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 22:54   #11
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, ho risolto il problema grazie a cdimauro; scusate il ritardo ma ho avuto un ulteriore contrattempo, come se non bastassero... -_-'
ecco qua le ultime modifiche:
Codice:
    public void generateKey(KeyCode key)
    {
        keys.set(key.value(), true);
        empty = false;
        queue.add(key);
    }


    public KeyCode extractKey()
    {
        KeyCode result = queue.remove();
        empty = queue.isEmpty();
        return result;
    }
ed inoltre il campo queue è diventato di tipo LinkedList<KeyCode>.

a questo punto la prima cosa che vedo è che c'è una duplicazione perché l'informazione di lista vuota è data sia dal campo empty sia da queue.isEmpty()...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 22:58   #12
Jocchan
Senior Member
 
L'Avatar di Jocchan
 
Iscritto dal: Jul 2005
Città: Silent Hill
Messaggi: 1471
Quote:
Originariamente inviato da 71104
a questo punto la prima cosa che vedo è che c'è una duplicazione perché l'informazione di lista vuota è data sia dal campo empty sia da queue.isEmpty()...
Una volta accertato che si tratta di una duplicazione, e che l'eliminazione di uno dei due elementi non comporta nessun danno, sai bene cosa bisogna fare
__________________
DIAMOND CRUSH - Aut viam inveniam, aut faciam.
Jocchan è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 23:09   #13
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Ho pensato io al refactoring.

Ho eliminato empty da tutte le parti e l'ho rimpiazzato soltanto in isQueueEmpty:
Codice:
    public boolean isQueueEmpty()
    {
      return queue.size() == 0;
    }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 23:16   #14
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, adesso il prossimo test (che testa il tipo di evento, cioè pressione o rilascio del tasto) richiede un po' di refactoring dei test precedenti:
Codice:
    public void testQueueItemRemoval()
    {
        input.generateKey(KeyCode.vk_Right);
        assertTrue(input.extractKey().key() == KeyCode.vk_Right);
    }


    public void testQueueSequenceOrder()
    {
        input.generateKey(KeyCode.vk_Right);
        input.generateKey(KeyCode.vk_Up);
        assertTrue(input.extractKey().key() == KeyCode.vk_Right);
        assertTrue(input.extractKey().key() == KeyCode.vk_Up);
    }
    
    
    public void testEventType()
    {
        input.generateKey(KeyCode.vk_Left, true);
        input.generateKey(KeyCode.vk_Left, false);
        assertTrue(input.extractKey().state());
        assertFalse(input.extractKey().state());
    }
testEventType è il nuovo test; ho assunto che la nuova classe KeyEvent che costituisce un nodo della lista abbia un metodo public state() che restituisce il tipo di evento (boolean quindi) e un metodo key() che restituisce il KeyCode.
la sequenza generata in questo test è semplice, pressione e rilascio di un tasto, ma poi si potrebbe fare un ulteriore test più robusto per testare combinazioni più complesse (casomai dopo però).

EDIT: ho cambiato il nome del metodo type() in state().

Ultima modifica di 71104 : 10-11-2005 alle 23:22.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 23:18   #15
Jocchan
Senior Member
 
L'Avatar di Jocchan
 
Iscritto dal: Jul 2005
Città: Silent Hill
Messaggi: 1471
Quote:
Originariamente inviato da 71104
la sequenza generata in questo test è semplice, pressione e rilascio di un tasto, ma poi si potrebbe fare un ulteriore test più robusto per testare combinazioni più complesse (casomai dopo però).
Mi raccomando facciamolo, stiamo implementando questa coda proprio per le situazioni più concitate quindi meglio assicurarci che tutto vada per il meglio
__________________
DIAMOND CRUSH - Aut viam inveniam, aut faciam.
Jocchan è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 23:21   #16
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da Jocchan
Mi raccomando facciamolo, stiamo implementando questa coda proprio per le situazioni più concitate quindi meglio assicurarci che tutto vada per il meglio
hai ragione
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 10-11-2005, 23:56   #17
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Per far passare il test ho implementato una classe KeyEvent in input, che serve a contenere l'informazione relativa al tasto premuto e al suo stato, modificando le parti di input che prima usavano KeyCode:
Codice:
    public class KeyEvent
    {
        private KeyCode keyCode;
        
        private boolean keyState;
        

        public KeyEvent(KeyCode keyCode, boolean keyState)
        {
            this.keyCode = keyCode;
            this.keyState = keyState;
        }
        

        public KeyCode key()
        {
            return keyCode;
        }
        

        public boolean state()
        {
           return keyState;   
        }
    
    }


    private LinkedList<KeyEvent> queue;


    private Input(AbstractKeyboard keyboard)
    {
        this.keyboard = keyboard;
        keys = new BitSet();
        queue = new LinkedList<KeyEvent>();
    }


    public void generateKey(KeyCode key, boolean state)
    {
        keys.set(key.value(), state);
        queue.add(new KeyEvent(key, state));
    }


    public void generateKey(KeyCode key)
    {
        generateKey(key, true);
    }


    public KeyEvent extractKey()
    {
        return queue.remove();
    }
Inoltre adesso generateKey(KeyCode key) utilizza generateKey(KeyCode key, boolean state), dove ho "centralizzato" tutto il codice.

Qui e in qualche altra parte si potrà effettuare del refactoring, ma per adesso m'interessa finire: il letto mi aspetta.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 11-11-2005, 00:04   #18
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Rimane da associate un timestamp a ogni evento generato. Il che vuol dire accertarsi che un tasto premuto prima NON possa avere un timestamp
maggiore di un tasto premuto dopo:
Codice:
    public void testEventTimestamp()
    {
        input.generateKey(KeyCode.vk_Left, true);
        input.generateKey(KeyCode.vk_Left, false);
        assertTrue(input.extractKey().getTimestamp() < input.extractKey().getTimestamp());
    }
A te Alberto.

P.S. Spero che Java non sia come il C, per cui un compilatore può processare liberamente gli argomenti di una funzione/metodo, altrimenti bisognerà modificare l'assert mettendo il primo timestamp in una variabile temporanea.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 11-11-2005, 00:22   #19
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
allora, ho risolto il test mettendo un campo timestamp in KeyEvent con relativo getter (il "setter" in questo caso sarebbe il costruttore, al quale ho aggiunto un parametro); ma c'è un piccolo dettaglio da notare: pur essendo il codice di implementazione corretto, il test inizialmente non passava perché i due timestamp risultavano identici, e non strettamente l'uno minore dell'altro; ho inserito tra le due inserzioni una piccola sleep da 100 ms, soluzione secondo me migliore del cambiare il simbolo < con <= (come proponeva cdimauro) in quanto il simbolo <= potrebbe rendere inutile il test (non testiamo realmente il caso, più realistico, in cui il primo timestamp è minore del secondo; cambiando le cose in teoria potrebbe pure saltare fuori l'errore che in realtà avevo sbagliato a scrivere il codice e quindi mettendo la sleep in realtà i due timestamp risultavano invertiti, o cose del genere, ma il test non lo evidenziava).
ecco come è diventato il test:
Codice:
    public void testEventTimestamp() throws InterruptedException
    {
        input.generateKey(KeyCode.vk_Left, true);
        Thread.sleep(100);
        input.generateKey(KeyCode.vk_Left, false);
        assertTrue(input.extractKey().getTimestamp() < input.extractKey().getTimestamp());
    }
ed ecco il codice della classe KeyEvent:
Codice:
    public class KeyEvent
    {
        private KeyCode keyCode;
        
        private boolean keyState;
        
        private long timestamp;
        

        public KeyEvent(KeyCode keyCode, boolean keyState, long timestamp)
        {
            this.keyCode = keyCode;
            this.keyState = keyState;
            this.timestamp = timestamp;
        }
        

        public KeyCode key()
        {
            return keyCode;
        }
        

        public boolean state()
        {
           return keyState;   
        }
        
        public long getTimestamp()
        {
            return timestamp;
        }
    
    }
a nanna
anzi, io non ancora, voglio aggiungere quell'ultimo test della sequenza di input complessa...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 11-11-2005, 00:25   #20
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
OK. Per adesso va bene: vado a nanna che il letto mi aspetta da almeno 3 ore :-D

Ci sono un po' di refactoring da fare, un po' di rename di metodi / attributi, e dovremmo discutere di qualche dettaglio come faceva notare Alberto.

A domani. Buonanotte a tutti
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
AMD Ryzen 5 7500X3D: la nuova CPU da gaming con 3D V-Cache per la fascia media AMD Ryzen 5 7500X3D: la nuova CPU da gaming con ...
SONY BRAVIA 8 II e BRAVIA Theatre System 6: il cinema a casa in formato compatto SONY BRAVIA 8 II e BRAVIA Theatre System 6: il c...
Jeff Bezos torna al comando, stavolta di...
Anthesi sceglie OVHcloud per digitalizza...
Cube presenta Trike Flatbed Hybrid 750, ...
Call of Duty Black Ops 7 peggio di Infin...
L'Italia è il secondo mercato per...
Wi-Fi superveloce anche in giardino? FRI...
La Ford Focus va ufficialmente in pensio...
Booking.com integra Revolut Pay: nasce i...
DGX Spark a 175 fps con ray tracing su C...
Red Dead Redemption 2 Enhanced è ...
3Dfx Voodoo 2, una GPU nata con la scade...
Apple Watch: la Mela dovrà versar...
TIM e Nokia insieme per potenziare il 5G...
Musk lancia la nuova era dei DM su X con...
A Dallas Fort Worth entrano in azione se...
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:11.


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