Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-09-2010, 16:10   #1
sisafra
Junior Member
 
Iscritto dal: Sep 2010
Messaggi: 9
[JAVA] java.lang.NullPointerException

Ciao a tutti, sono alle prime armi con la programmazione in java..e tra un po' proverò a sostenere l'esame. all'università.. Programmare non mi è mai piaciuto, ma bisogna farlo..Il programma che posto qui è quindi, probabilmente, per molti di voi molto semplice..supera la fase di compilazione ma mi dà poi un errore in esecuzione..Potreste aiutarmi a risolvere il problema? Grazie



import java.util.Scanner;

interface CO
{ int size();
boolean isEmpty();
void enqueue(Comparable x);
Comparable dequeue();
void sort();
}

class MyCO implements CO
{ private Comparable[] v ;
private int vsize;
private int primo;
private int ultimo;

public MyCO()
{ Comparable[] v = new Comparable[1];
vsize = 0;
primo = 0;
ultimo = v.length-1;
}

public int size()
{ return vsize; }

public boolean isEmpty()
{ return (vsize==0); }

public void enqueue(Comparable x)
{ if ( x == null)
throw new IllegalArgumentException();
Comparable[] newv = new Comparable[vsize*2];
if (vsize == v.length) RIGA 34
System.arraycopy(v, 0, newv, 0, vsize);
newv = v;
v[ultimo] = x;
ultimo++;
vsize++;
}

public Comparable dequeue()
{ if (vsize == 0)
throw new IllegalArgumentException();
Comparable rem = v[primo];
vsize--;
return rem;
}

public void sort()
{ Comparable[] t = new Comparable[vsize];
for ( int i = 0; i<v.length; i++)
{ int minimo = i;
for ( int j = i+1; j<v.length; j++)
if (v[minimo].compareTo(v[j]) >0)
minimo = j;
Comparable temp = v[minimo];
v[minimo] = v[i];
v[i] = temp;
}
}
}

/* Scrivere una classe Main.java di prova che:
– crei due esemplari della classe MiaCO di nome uno e due
– legga dall'ingresso standard una sequenza di numeri interi
in ordine casuale (un dato per riga), li
inserisca sia nella coda uno che nella coda due. Esegua 5 (cinque)
operazioni di dequeue() sulla coda uno, ordini la coda e la vuoti
trasferendone il contenuto sull'uscita standard (un dato per riga, i dati d
ovranno risultare ordinati), trasferisca sull'uscita standard una riga vuota
e vuoti la coda due trasferendo i dati sull'uscita standard, uno per riga.
In questo caso i dati in uscita dovranno essere nello stesso ordine dei dati in ingresso
*/


public class Main
{ public static void main (String[] args)
{ MyCO uno = new MyCO();
MyCO due = new MyCO();
Scanner c = new Scanner (System.in);
while (c.hasNext())
{ Integer w = new Integer(c.nextLine());
uno.enqueue(w); RIGA 84
due.enqueue(w);

}
uno.dequeue();
uno.dequeue();
uno.dequeue();
uno.dequeue();
uno.dequeue();
uno.sort();
while (!uno.isEmpty())
System.out.println(uno.dequeue());
System.out.println();
while (!due.isEmpty())
System.out.println(due.dequeue());
}
}

L'errore lanciato è

Exception in thread "main" java.lang.NullPointerException
at MyCO.enqueue(Main.java:34)
at Main.main (Main.java:84)

Evidenzio nel codice le righe..se qualcuno può aiutarmi..la maggior parte dei programmi che scrivo superano la compilazione ma poi mi viene sempre fuori questo errore..cosa sbaglio??

Ultima modifica di sisafra : 08-09-2010 alle 16:16.
sisafra è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 00:05   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ciao,
premesso che *NON* ti ho risolto l'esercizio, e che il codice postato qui sotto *NON E'* una soluzione al testo dell'esercizio, ci sono molte "sviste" nel codice.

Questo codice qui sotto è la copia del tuo, dove ci sono degli errori (sono tutti errori semantici, la sintassi era corretta) li ho commentati e subito sotto ho scritto una variante (colorata in marroncino).
Il primo errore che dovresti controllare è quello evidenziato in rosso, che poi è la causa della tua NullPointerException.
Però come vedi, ne ho trovati molti altri (darebbero origine a altre eccezioni e inconsistenze). Prova a ragionarci sopra.
Codice:
import java.util.Scanner;

interface CO
{
    int size();
    boolean isEmpty();
    void enqueue(Comparable x);
    Comparable dequeue();
    void sort();
}


class MyCO implements CO
{
        private Comparable[] v ;
        private int vsize;
        private int primo;
//        private int ultimo;

    public MyCO() {

//        Comparable[] v = new Comparable[1];
        v = new Comparable[1];

        vsize = 0;
        primo = 0;
//        ultimo = v.length-1;
    }

    public int size() {
        return vsize;
    }

    public boolean isEmpty() {
//        return (vsize==0);
        return primo>=vsize;
    }

    public void enqueue(Comparable x) {
        if (x == null)
            throw new IllegalArgumentException();

//        Comparable[] newv = new Comparable[vsize*2];
//        if (vsize == v.length) //RIGA 34
//            System.arraycopy(v, 0, newv, 0, vsize);
//        newv = v;
        if (vsize == v.length) {
            Comparable[] newv = new Comparable[v.length*2];
            System.arraycopy(v, 0, newv, 0, vsize);
            v = newv;
        }

        v[vsize] = x;
//        ultimo++;
        vsize++;
    }

    public Comparable dequeue() {
//        if (vsize == 0)
        if (primo >= vsize)
            throw new IllegalArgumentException();
        Comparable rem = v[primo];
//        vsize--;
        primo++;
        return rem;
    }

//    public void sort() {
//        Comparable[] t = new Comparable[vsize];
////        for (int i=0; i<v.length; i++) {
//        for (int i=0; i<vsize-2; i++) {
//            int minimo = i;
////            for (int j=i+1; j<v.length; j++)
//            for (int j=i+1; j<vsize-1; j++)
//                if (v[minimo].compareTo(v[j]) > 0)
//                    minimo = j;
//            Comparable temp = v[minimo];
//            v[minimo] = v[i];
//            v[i] = temp;
//        }
//    }
    /**
     * Implementato come un insertion sort.
     */
    public void sort() {
        for(int i=1; i<vsize; i++) {
            Comparable tmp = v[i];
            int k = i;
            for(; k>0 && tmp.compareTo(v[k-1])<0; k--)
                v[k] = v[k-1];
            v[k] = tmp;
        }
    }
}


public class Main
{
    public static void main (String[] args) {
        MyCO uno = new MyCO();
        MyCO due = new MyCO();

        Scanner c = new Scanner (System.in);

//        while (c.hasNext()) {
//            Integer w = new Integer(c.nextLine());
//            uno.enqueue(w); //RIGA 84
//            due.enqueue(w);
//        }
        while(true) {
            try {
                Integer w = c.nextInt();
                uno.enqueue(w);
                due.enqueue(w);
            } catch(RuntimeException ex) {
                break;
            }
        }

        System.out.println();

        uno.sort();
        while (!uno.isEmpty())
            System.out.println(uno.dequeue());
        
        System.out.println();
        
        while (!due.isEmpty())
            System.out.println(due.dequeue());
    }
}
Per leggere i dati dallo standard input ho usato [Scanner].nextInt() assumendo che l'utente digiti solo valori interi, e le letture sono contenute in un ciclo infinito (while(true)) che cattura input finchè l'utente non digita e spedisce qualcosa di diverso da un numero intero (ho sfruttato il fatto che [Scanner].nextInt() lancia un'eccezione se il rpossimo token che legge non è un intero).
__________________

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-09-2010 alle 00:26.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 07:56   #3
sisafra
Junior Member
 
Iscritto dal: Sep 2010
Messaggi: 9
Grazie..

Ciao, ti ringrazio molto, effettivamente l'errore che genera null è proprio STUPIDO, non ho mai fatto una cosa del genere -.-..e non me ne accorgevo nemmeno.. sarà che ero anche fusa da una giornata di programmazione..ora ragiono un po' sulle tue varianti..e vediamo se funziona..grazie davvero ..
sisafra è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 09:06   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da sisafra Guarda i messaggi
Ciao, ti ringrazio molto, effettivamente l'errore che genera null è proprio STUPIDO, non ho mai fatto una cosa del genere -.-..e non me ne accorgevo nemmeno.. sarà che ero anche fusa da una giornata di programmazione..ora ragiono un po' sulle tue varianti..e vediamo se funziona..grazie davvero ..
Commettere errori è normalissimo, nessuno scrive codice esente da difetti, specie se si sta imparando (sbagliando si impara, dice il proverbio ).

Il codice la sopra compila ed esegue senza errori, il problema è un altro (suppongo): per risolvere l'esercizio dovrai ripensare all'implementazione dell'interfaccia CO. L'attuale MyCO implementata è una struttura dati di tipo FIFO (una coda) solo che è implementata con un array che ha una politica di "resize" e mantenimento dello spazio un pochino bizzarra (cresce sempre, non recupera mai lo spazio inutilizzato).

Per darti uno spunto su cui riflettere, prova a pensare come cambia il tasso di crescita dell'array interno alla coda man mano che vengono allocati sempre più elementi (ad esempio 10, 100, o 1000 elementi) prima con il metodo attuale enque, e dopo con questa variante:
Codice:
///////
'elements' è l'array di Comparable interno alla coda.
'head' è l'indice della testa (primo elemento della coda).
'tail' è l'indice della coda (indice dove inserire il prossimo elemento, ovvero l'indice sucessivo a quello dell'utimo elemento presente).
//////
if (head == tail) {
    int n = elements.length;
    int r = n - head; // number of elements to the right of head
    int newCapacity = n*2;
    Comparable[] arr = new Comparable[newCapacity];
    System.arraycopy(elements, head, arr, 0, r);
    System.arraycopy(elements, 0, arr, r, head);
    elements = arr;
    head = 0;
    tail = n;
}
///////
__________________

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
Old 09-09-2010, 19:15   #5
sisafra
Junior Member
 
Iscritto dal: Sep 2010
Messaggi: 9
..mi era stato chiesto dal testo dell'esercizio che l'array crescesse sempre.. -.- .. ma un'altra domanda..mi hai parlato di errori semantici, ma la sintassi era corretta..cioè vuoi dire errori di concetto??
sisafra è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 21:55   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da sisafra Guarda i messaggi
ma un'altra domanda..mi hai parlato di errori semantici, ma la sintassi era corretta..cioè vuoi dire errori di concetto??
Sì, esatto.
Ad esempio l'errore di assegnare, nel costruttore, l'array di Comparable appena allocato ad una variabile locale, invece che al membro di istanza della classe. La sintassi era corretta, è proprio la logica ad essere sbagliata (chiaramente questa in particolare è stata una svista).

Quote:
..mi era stato chiesto dal testo dell'esercizio che l'array crescesse sempre.. -.- ..
Ma certo, infatti anche nello spezzone di codice che ti ho postato l'array cresce sempre; semplicemente ad ogni raddoppio della dimensione
recupera lo spazio inutilizzato delle 'celle' vuote dell'array posizionate a sinistra del puntatore della head, che sono diventate tali (inutilizzate) a seguito delle operazioni di "dequeue".
Quel codice non è farina del mio sacco: l'ho preso pari-pari dalla attuale implementazione della classe java.util.ArrayDeque del JDK.
__________________

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 : 10-09-2010 alle 08:11.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2010, 08:17   #7
sisafra
Junior Member
 
Iscritto dal: Sep 2010
Messaggi: 9
...

Ora dò un'occhiata al'ArrayDeque di cui parli..certo, ci vuole decisamente molta molta pratica, ma gli esercizi sono pochissimi, e i temi d'esame anche..non so dove andare a pescare qualcosa di utile per farmi entrare in testa le cose importanti.. Ti ringrazio molto comunque ..
sisafra è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Panasonic LUMIX TZ300: la nuova compatta...
La società aerospaziale italiana ...
Il Politecnico di Milano guiderà ...
Amazon Leo punta ad aumentare la cadenza...
Pro Type Ergo: Razer si lancia a gamba t...
Artemis II: dal guasto risolto alla toil...
Le immagini e i video più spettac...
Previsioni drastiche di TrendForce: la D...
La PS6 portatile sarà più potente della ...
Toshiba annuncia i primi dischi FC-MAMR ...
Amazon Leo offrirà l'accesso a Internet ...
Alienware presenta i nuovi desktop Area-...
Fiat 600 benzina senza ibrido: 101 CV, c...
DJI Mini 4K Combo a 269€ o DJI Neo da 14...
Addio agli sprechi nel riciclo: il Fraun...
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:25.


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