Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
La Fondazione Chips-IT ha presentato a Pavia il piano strategico 2026-2028 per rafforzare l'ecosistema italiano dei semiconduttori. Con un focus su ricerca, design, talenti e infrastrutture, la Fondazione punta a consolidare il ruolo dell'Italia nel Chips Act europeo, sostenendo innovazione, collaborazione industriale e sovranità tecnologica.
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Al Museo Alfa Romeo di Arese, Nutanix ha riunito clienti, partner ed esperti per .Next On Tour Italia e per mostrare come l’infrastruttura hybrid multicloud possa diventare il fondamento dell’innovazione, con una piattaforma capace di unificare applicazioni tradizionali, moderne architetture cloud-native e nuovi scenari basati sull’intelligenza artificiale
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti
Il Lenovo LOQ 15i Gen 10 (15IRX10) offre prestazioni convincenti grazie al Core i7-13650HX e alla RTX 5060 Laptop a 100W, mantenendo un prezzo competitivo tra 1100 e 1300 euro. Costruzione solida, buon display e ampia espandibilità lo rendono una scelta equilibrata per chi cerca un notebook gaming accessibile ma moderno.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-01-2006, 21:23   #1
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
[Task 9.1] 71104 Vs. TigerShark Pair Reloaded

Allora..
dopo tutte 'ste incomprensioni finalmente abbiamo deciso di iniziare stasera..
e io spero anche di finire dato che nei prox giorni non posso...
a tra poco a tutti i nostri internet-ascoltatori!
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:21   #2
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
TestList

Allora..
dopo un'accesa discussione abbiamo deciso di seguire il suggerimento di fek e di fare estendere inizialmente alla calsse Chest il tipo Gem.
Questo ha alcune conseguenze...
a quanto abbiamo capito i test per la creazione dei Chest e per tutti i metodi in comune con la classe Gem sono già testati, quindi la prima parte del nostro task consiste in un semplice refactoring.
Invece per la seconda parte dovremo testare che la probabilità di estrazione dei Chest sia quella voluta....
Per questo direi che ci sono essenzialmente due test fondamentali:
1)Che i Chest vengano generati in media alla frequenza voluta
2)Che due Chest consecutivi non possano uscire (è corretta quest'assunzione???Joc, Vic, Fek????)
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:24   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
secondo me si, il secondo punto è esatto.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:30   #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
Quote:
Originariamente inviato da ^TiGeRShArK^
2)Che due Chest consecutivi non possano uscire (è corretta quest'assunzione???Joc, Vic, Fek????)
No, non devono uscire due chest dello stesso tipo consecutivi...guardate l'ltimo post di Jocchan nel thread delal storia 9...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:56   #5
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
ecco il codice del primo test:
Codice:
public void TestChestType()
    {
        assertTrue("EMERALD_CHEST is not correctly recognized as a Chest", GemType.EMERALD_CHEST.isChest());
        assertTrue("RUBY_CHEST is not correctly recognized as a Chest", GemType.RUBY_CHEST.isChest());
        assertTrue("SAPPHIRE_CHEST is not correctly recognized as a Chest", GemType.SAPPHIRE_CHEST.isChest());
        assertTrue("TOPAZ_CHEST is not correctly recognized as a Chest", GemType.TOPAZ_CHEST.isChest());
        assertTrue("DIAMOND_CHEST is not correctly recognized as a Chest", GemType.DIAMOND_CHEST.isChest());
        assertFalse("EMERALD is not correctly recognized as a Gem", GemType.EMERALD.isChest());
        assertFalse("RUBY is not correctly recognized as a Gem", GemType.RUBY.isChest());
        assertFalse("SAPPHIRE is not correctly recognized as a Gem", GemType.SAPPHIRE.isChest());
        assertFalse("TOPAZ is not correctly recognized as a Gem", GemType.TOPAZ.isChest());
        assertFalse("DIAMOND is not correctly recognized as a Gem", GemType.DIAMOND.isChest());
    }
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:05   #6
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, ed ecco come è diventata la classe GemType:
Codice:
public final class GemType
{
    public static final GemType EMERALD = new GemType("emerald", 40, false);
    public static final GemType RUBY = new GemType("ruby", 50, false);
    public static final GemType SAPPHIRE = new GemType("sapphire", 60, false);
    public static final GemType TOPAZ = new GemType("topaz", 80, false);
    public static final GemType DIAMOND = new GemType("diamond", 100, false);
    
    public static final GemType EMERALD_CHEST = new GemType("emerald", 40, true);
    public static final GemType RUBY_CHEST = new GemType("ruby", 50, true);
    public static final GemType SAPPHIRE_CHEST = new GemType("sapphire", 60, true);
    public static final GemType TOPAZ_CHEST = new GemType("topaz", 80, true);
    public static final GemType DIAMOND_CHEST = new GemType("diamond", 100, true);
    
    private final String name;
    private final int score;
    private final boolean isChest;
    
    
    GemType(String name, int score, boolean isChest)
    {
        this.name = name;
        this.score = score;
        this.isChest = isChest;
    }
    
    
    public String name()
    {
        return name;
    }
    
    
    public int score()
    {
        return score;
    }
    
    
    public boolean isChest()
    {
        return isChest;
    }
}
ora, spiegazione: siccome ci è stato richiesto di derivbare una classe Chest da Gem, io e TigerShark abbiamo deciso di implementare quel metodo per capire quand'è che il metodo statico Gem.create deve creare un oggetto Gem e quand'è che deve creare Chest, in base a cosa ritorna il metodo isChest dall'oggetto gemType passato come parametro a create.

ora ci sarebbe da testare se create in base a cosa viene ritornato da isChest capisce se creare un oggetto Gem o un oggetto Chest, e la cosa riesce un po' difficoltosa a causa del fatto che in Java che io sappia non è direttamente possibile ricavare RTTI sul tipo di un oggetto, quindi penso di aggiungere un metodo virtuale isChest anche in Gem e di sovrascriverlo in Chest; fek e vic, se pensate che non ne valga la pena fermateci e reverteremo.

intanto scrivo il test per questo metodo che TigerShark implementerà.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:23   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
prossimi test:
Codice:
    public void testGemIsNotChest()
    {
        Gem gem = Gem.createForTesting();
        assertFalse(gem.isChest());
    }
    
    public void testChestIsChest()
    {
        Gem gem = Chest.createForTesting();
        assertTrue(gem.isChest());
    }
questi due test servono a testare che isChest funzioni correttamente e che sia un metodo virtuale.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:34   #8
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da 71104
ora, spiegazione: siccome ci è stato richiesto di derivbare una classe Chest da Gem, io e TigerShark abbiamo deciso di implementare quel metodo per capire quand'è che il metodo statico Gem.create deve creare un oggetto Gem e quand'è che deve creare Chest, in base a cosa ritorna il metodo isChest dall'oggetto gemType passato come parametro a create.
Ti spezzo un braccio se ci provi. (Adoro le minacce fisiche )

Evitare metodi tipo isChest(), getType(), etc etc, sono l'esatto motivo per il quale esistono praticamente meta' dei Design Pattern. Trovate sicuramente un modo alternativo (un factory method in GemType?).
fek è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:35   #9
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da 71104
prossimi test:
Codice:
    public void testGemIsNotChest()
    {
        Gem gem = Gem.createForTesting();
        assertFalse(gem.isChest());
    }
    
    public void testChestIsChest()
    {
        Gem gem = Chest.createForTesting();
        assertTrue(gem.isChest());
    }
questi due test servono a testare che isChest funzioni correttamente e che sia un metodo virtuale.

REVEEEEEEEEEEEEEEEEEEEEERT!
fek è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:43   #10
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Fek...ma tu quindi la Reflection la usi??
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:54   #11
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
è stata colpa mia ke avrei dovuto pensarci avendolo usato un paio di volte questo pattern....
ma stasera sono proprio fuso

__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:55   #12
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
eh...? :|
non ho capito cos'è che non devo fare... O_o'
che tipo di metodi devo evitare?

mi sembrava una soluzione semplicissima quella che avevo inventato... o_O' e funzionava pure...

TigerShark dice di aver capito che dobbiamo cambiare e fare in modo che Gem e Chest derivino da una stessa classe di base, ma... non eri stato tu a imporci di derivare Chest da Gem??? :|

boh, a me sembrava che andasse tutto liscio... che dobbiamo fare di preciso?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:57   #13
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
AAAAAAAAAAHHHHHHHHHHHHHHH FERMIHOCAPITOTUTTO!!!
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:57   #14
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Scusatemi... Dal momento in cui avete GemType.isChest() cosa ve ne fate della derivazione? Tenete la classe Gem ormai no?
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:58   #15
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
....mi sa ke io sono OUT.....
stasera nn capisco piu' niente e nei prox giorni sono a reggio....

ke si fa?
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:59   #16
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
TigerShark, ricominciamo daccapo, e stavolta andremo più veloci; allora, ho capito il democratico suggerimento di fek, dobbiamo cancellare isChest e mettere un public static Gem createByType, giusto?

scrivo il test...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2006, 00:00   #17
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da Ufo13
Scusatemi... Dal momento in cui avete GemType.isChest() cosa ve ne fate della derivazione? Tenete la classe Gem ormai no?
no, serviva anche la derivazione, altrimenti era tutto più complesso, ma adesso cambiamo tutto.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2006, 00:03   #18
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
C'è un volontario x continuare con 71104 ke io nei prox giorni non ci sarò???
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2006, 00:11   #19
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Io prima di sabato niente mi spiace
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2006, 00:11   #20
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
le cose si complicano: a TigerShark è caduta nuovamente la linea e a me per continuare serve di sapere la sintassi di instanceof, che serve in Java per ricavare RTTI; lo devo usare per forza nei test se non devo fare metodi virtuali, altrimenti il metodo statico Gem.create rimarrà non testato...
siccome s'è fatto tardi è meglio continuare domani, faccio un commit per essere sicuri che la codebase non contenga quei metodi virtuali che avevamo iniziato a scrivere.
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica Fondazione Chips-IT, l'Italia alla riscossa nei ...
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
180 Hz in 5K? Il nuovo monitor di ASUS m...
L'Europa salva le auto termiche? Forse s...
Total War: Warhammer 40K è realt&...
NVIDIA rassicura il mondo HPC: il format...
Lenny Kravitz diventa un villain in 007 ...
Saros rinviato ad aprile 2026: il nuovo ...
EPYC Embedded 2005: AMD punta su efficie...
Addio Calibri, è troppo woke: l'a...
Divinity: il nuovo, inquietante progetto...
Amazon senza regole: tornano in sconto i...
Oral-B iO in super sconto: spazzolini el...
Blink in super sconto: videocamere smart...
Amazon rilancia gli sconti tech: Echo, F...
Star Wars Galactic Racer: si torna a cor...
La strana scelta di Ford: nel 2026 la Ma...
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: 14:31.


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