Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-09-2010, 17: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 17:16.
sisafra è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 01: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 01:26.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2010, 08: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, 10: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, 20: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, 22: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 09:11.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2010, 09: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


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
Project Panama: ecco come Anthropic ha d...
MrBeast entra nel fintech: Beast Industr...
Arrivano i nuovi server Bare Metal 2026 ...
Stop alla distribuzione dei driver di st...
Serie TV God of War: scelto anche l'atto...
Riot Games dimezza il team di 2XKO dopo ...
FRITZ! in super offerta su Amazon: ripet...
L'AI doveva farci lavorare meno: e se st...
DREAME X50 Ultra Complete a 899€ su Amaz...
Rimodulazione TIM: aumenti fino a 2,99 e...
Amazon sblocca i prezzi con coupon e sco...
Action cam Insta360 in super offerta su ...
Fallout 76 Sorgenti Brucianti: tanta car...
Scope elettriche super potenti a confron...
Tutti i Google Pixel 10 sono scontati su...
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: 13:19.


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