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 08-07-2009, 21:26   #1
Nukles
Senior Member
 
L'Avatar di Nukles
 
Iscritto dal: Oct 2001
Città: Roma - Norge
Messaggi: 1354
[Java] Invocare metodi e costruttori che puntano a null

Ciao a tutti!

Sto svolgendo dei metodi di test per un'applicazione. Siccome è molto lungo istanziare ogni classe con più parametri d'ingresso oltre quelli che mi interessano (es. se ho classe Persona e voglio creare più persone con eta diversa e poi fare le verifiche sulla loro età, non mi importa il loro cognome...).

Mi chiedev se esiste qualche modo per invocarli dando in input al costruttore qualcosa come null (dato che null non lo accetta in compilazione...).

Cosa posso mettere?

Ad esempio

Codice:
public class Persona {
    ...
    public Persona( String nome, String cognome, int eta ) {...}
    ...
}
Nel metodo di Test vorrei fare qualcosa del genere

Codice:
....
public void testPersona {
   Persona p = new Persona(null, null, 30);
   Persona q = new Persona(null, null ,34);
   assertTrue(64, p.getEta() + q.getEta() );
}
...
__________________
har jeg kommet fra Norge !!!!
I've been for a walk on a winter's day, I'd be safe and warm if I was in L.A. ...
Quant'è bella giovinezza, che si fugge tuttavia; chi vuol esser lieto, sia: non si iscriva a ingegneria!
Nukles è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 01:18   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2782
Dai a tutti un nome farlocco, sempre lo stesso... O se preferisci una stringa vuota.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 09:48   #3
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
*EDIT: vedi sotto.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 09-07-2009 alle 10:21.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 10:21   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Visto che hai la neccessità di eseguire dei test sulle classi che scrivi (pratica buona e giusta) perchè non ti appoggi a qualche libreria per lo Unit Testing?
Ad esempio in NetBeans c'è JUnit.

Se non sai cos'è la pratica chiamata "unit testing" in rete trovi zillionate di risorse e spiegazioni.

Tanto per darti un esempio (usando una classe di fantasia).

La classe da testare:
Codice:
public class Persona
{
    String nome;
    String cognome;
    GregorianCalendar dataNascita;

    public Persona(String n, String c, GregorianCalendar d)
    {
        nome = n;
        cognome = c;
        dataNascita = d;
    }

    public int getEta()
    {
        GregorianCalendar today = getToday();
        return  today.add(Calendar.YEAR, -dataNascita.get(Calendar.YEAR));
    }

    @Override
    public String toString()
    {
        Object[] values = {nome, cognome, getEta()};
        String pattern = "nome: {0}, cognome: {1}, eta': {2}";
        return  MessageFormat.format(pattern, values);
    }

    protected GregorianCalendar getToday()
    {
        Date now = new Date();
        GregorianCalendar today = new GregorianCalendar();
        return  today.setTime(now);
    }
}
Unit test della classe Persona:
Codice:
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import static org.junit.Assert.*;
/**
 * Unit test for class Persona
 */
public class PersonaTest
{
    Persona marco, giorgio, luca;

    @Before
    public void setUp()
    {
        marco =
        new Persona("Marco", "Rossi", new GregorianCalendar(1979,0,15));
        giorgio = 
        new Persona("Giorgio", "Rossi", new GregorianCalendar(1984,5,7));
        luca =
        new Persona("Luca", "Bianchi", new GregorianCalendar(1999,11,24));
    }

    @After
    public void tearDown()
    {
        marco = giorgio = luca = null;
    }

    /**
     * Test of getEta method, of class Persona
     */
    @Test
    public void testGetEta()
    {
        System.out.println("*PersonaTest - testGetEta()");
        assertEquals(30, marco.getEta());
        assertEquals(25, giorgio.getEta());
        assertEquals(10, luca.getEta());
    }

    /**
     * Test of toString method, of class Persona.
     */
    @Test
    public void testToString()
    {
        System.out.println("*PersonaTest - testToString()");
        String expected = null;
        expected = "nome: Marco, cognome: Rossi, eta': 30";
        assertEquals(expected, marco.toString());
        expected = "nome: Giorgio, cognome: Rossi, eta': 25";
        assertEquals(expected, giorgio.toString());
        expected = "nome: Luca, cognome: Bianchi, eta':10";
        assertEquals(expected, luca.toString());
    }
Disclaimer: non ho compilato il codice percui potrebbe non essere corretto; serve solo per darti l'idea.


Il punto è che nella classe per lo unit test di Persona che ho scritto, come vedi ci sono due metodi 'setUp' e 'tearDown'.
'setUp' viene chiamato prima subito prima di invocare ogni metodo di test; 'tearDown' viene chiamato subito dopo l'invocazione di ogni metodo di test.

Qui li ho sfruttati per costruire 3 reference di Persona che vengono usate nel test, e subito dopo vengono resettate.
Questo permette di evitare la propagazione di eventuali "side-effect" agli atri metodi di test, che sono così ben isolati.

Se non ti interessa diversificare in base ai campi 'nome' e 'cognome' (ma per far funzionare l'oggetto, ovvero per costruirlo, sono neccessari) basta fare una cosa così, nella classe di test:
Codice:
public class PersonaTest
{
    Persona persona1, persona2, persona3;

    @Before
    public void setUp()
    {
        String s= "";

        persona1 = new Persona(s, s, new GregorianCalendar(1979,0,15));
        persona2 = new Persona(s, s, new GregorianCalendar(1984,5,7));
        persona3 = new Persona(s, s, new GregorianCalendar(1999,11,24));
    }

    @After
    public void tearDown()
    {
        persona1 = persoan2 = persona3 = null;
    }

    ....
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 09-07-2009 alle 10:27.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 11:45   #5
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Se ti ritrovi ad avere una classe con molti parametri nel costruttore, puoi considerare un Builder Pattern.
Ha diversi vantaggi, tipo permettere alla tua classe di rimanere immutabile, simulare parametri opzionali e rendere più flessibile la costruzione di un oggetto di quel tipo.
Ovviamente ha lo svantaggio di aumentare la complessità del codice.

Esempio copia/incollato (non è farina del mio sacco):
Codice:
// Builder Pattern
public class NutritionFacts {
  private final int servingSize;
  private final int servings;
  private final int calories;
  private final int fat;
  private final int sodium;
  private final int carbohydrate;

  public static class Builder {
    // Required parameters
    private final int servingSize;
    private final int servings;
    
    // Optional parameters - initialized to default values
    private int calories = 0;
    private int fat = 0;
    private int carbohydrate = 0;
    private int sodium = 0;

    public Builder(int servingSize, int servings) {
      this.servingSize = servingSize;
      this.servings = servings;
    }

    public Builder calories(int val) {
      calories = val;
      return this;
    }

    public Builder fat(int val) {
      fat = val; 
      return this;
    }

    public Builder carbohydrate(int val) {
      carbohydrate = val;
      return this;
    }

    public Builder sodium(int val) {
      sodium = val;
      return this;
    }

    public NutritionFacts build() {
      return new NutritionFacts(this);
    }
  }

  private NutritionFacts(Builder builder) {
    servingSize = builder.servingSize;
    servings = builder.servings;
    calories = builder.calories;
    fat = builder.fat;
    sodium = builder.sodium;
    carbohydrate = builder.carbohydrate;
  }
}
E poi lo usi cosi...
Codice:
NutritionFacts cocaCola = new NutritionFacts.Builder(240, 8).
    calories(100).sodium(35).carbohydrate(27).build();
Ma se hai solo 3 parametri come nell'esempio che hai riportato non è il caso...
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 16:10   #6
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
Quote:
Originariamente inviato da Nukles
Mi chiedev se esiste qualche modo per invocarli dando in input al costruttore qualcosa come null (dato che null non lo accetta in compilazione...).
Veramente???
scusate ma cado proprio dalle nuvole....e perchè mai??
Io pensavo che al massimo lanciasse una NullPointer nel caso in cui ci si riferisce alla variabile = null, infatti ho fatto una prova (banalissima) e compila senza errori:

Codice:
public class Persona {
    String n;
    int e;

    public Persona( String nome, int eta ) {
        n=nome;
        e = eta;
    }

    public static void main(String[] args) {
        Persona p = new Persona(null, 50);
    }
}
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 09-07-2009, 16:33   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da Oceans11 Guarda i messaggi
Veramente???
scusate ma cado proprio dalle nuvole....e perchè mai??
Io pensavo che al massimo lanciasse una NullPointer nel caso in cui ci si riferisce alla variabile = null, infatti ho fatto una prova (banalissima) e compila senza errori:
Sì sì, infatti, credo che l'utente intendesse la possibilità di fregasene dei primi due parametri nel test senza dover "inquinare" la classe mettendo degli ulteriori costruttori solo per gestire questa esigenza. Chiaro che puoi sempre e comunque passare una reference che vale null, di certo il compilatore non te lo vieta.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è 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 ...
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...
LG Sound Suite: al CES il sistema audio ...
Avengers Doomsday, il primo trailer &egr...
La crisi delle memorie non farà sconti a...
Il trailer più atteso dell'anno &...
I gamer vogliono i monitor OLED: sopratt...
Samsung alza l’asticella dei televisori ...
Energie rinnovabili 2025: quasi 42% del ...
Le auto elettriche volano in tutta Europ...
Nuovo look per la finestra Esegui su Win...
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: 23:11.


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