Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-10-2004, 11:03   #1
boysna
Senior Member
 
Iscritto dal: Mar 2004
Città: castel san giorgio(salerno)
Messaggi: 1218
eccezioni in java

dovrei compilare un programma java che implementa la struttura dati "coda" usando due "stack". Il programma ke ho fatto viene compilato ma non capisco perchè mi lancia la "java.lang.ArrayIndexOutOfBoundsException"
at queue_con_due_stack.stackqueue.inverti(stackqueue.java:76)
at queue_con_due_stack.stackqueue.stackqueue_front(stackqueue.java:49)
at queue_con_due_stack.test.main(test.java:22)

Il codice è il seguente:

package queue_con_due_stack;

import javax.swing.JOptionPane;

public class test {

public static void main(String [] args) {

stackqueue queue = new stackqueue(10);
String num_oggetti_input =
JOptionPane.showInputDialog("Oggetti in coda?");
int num_oggetti = Integer.parseInt(num_oggetti_input);

for (int i=0; i < num_oggetti; i++)
{
String oggetto_inserito_input =
JOptionPane.showInputDialog("Inserisci il successivo");
Object o = oggetto_inserito_input;
queue.stackqueue_enqueue(o);
}

System.out.println("L'elemento al front è" + queue.stackqueue_front());

queue.stackqueue_dequeue();
System.out.println("L'elemento al front è stato eliminato");
System.out.println("Ora al front c'è:" + queue.stackqueue_front());

if (queue.stackqueue_isEmpty())
System.out.println("Coda vuota");
else
System.out.println("Coda non vuota");

System.out.println("Al momento vi sono" + queue.stackqueue_size() + "elementi");
System.exit(0);


}
}



package queue_con_due_stack;

public class stackqueue implements queue_con_due_stack {

private Object[] array2;
public int capacity;
public int top = -1;
public int f = -1;
private Object[] primo_array;
private Object[] secondo_array;

public stackqueue(int capacity)
{
int n = capacity;
primo_array = new Object[capacity];
secondo_array = new Object[capacity];
}

public int stackqueue_size()
{
return (top - f);
}

public boolean stackqueue_isEmpty()
{
if(top - f ==0)
return true;
else
return false;
}

public void stackqueue_enqueue(Object o)
{
primo_array[top + 1]= o;
top = top + 1;
}

public Object stackqueue_front()
{
secondo_array = inverti(primo_array);
return secondo_array[f + 1];
}

public Object stackqueue_dequeue()
{
secondo_array = inverti(primo_array);
Object o = pop();
primo_array = inverti(secondo_array);
f = f + 1;
return o;
}

public Object pop()
{
Object temp = secondo_array[f];
secondo_array[f] = null;
top = top + 1;
return temp;
}

public Object[] inverti(Object[] array)
{
Object[] array2 = new Object[capacity];
int j = 0;
for(int i = top; i>= 0; i--, j++)
{
array2[j] = array[i];
}
return array2;
}
}



package queue_con_due_stack;

interface queue_con_due_stack
{

public int stackqueue_size();

public boolean stackqueue_isEmpty();

public void stackqueue_enqueue(Object o);

public Object stackqueue_front();

public Object stackqueue_dequeue();

public Object[] inverti(Object[] array);

public Object pop();

}


datemi una mano vi prego....
boysna è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2004, 12:10   #2
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9464
Il codice non lo guardero' mai...
Anche perche' un minimo di commento non farebbe male...
Cmq. la causa di errore e' presto detta. Tenti di accedere ad un array in una posizione che non esiste.

Ad esempio se hai:
int[] array = new int[5];
e provi a fare:
int num = array[5];
viene lanciata una AIOOBE...
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 23-10-2004, 12:54   #3
end.is.forever
Senior Member
 
Iscritto dal: Jul 2004
Messaggi: 1578
Non l'ho ancora guardato bene perchè è un po intricato, comunque intanto ti do un consiglio:
evita di dare a dei membri dei valori che possano dare errori come questo.

Per esempio tutti quei -1 che inizializzi, sono sicuramente causa di qualche array out of bounds.

Oppure se li vuoi inizializzare a -1, metti qualche controllo in tutti i metodi che li usano e fagli generare un eccezione in quei casi, così il debug è piu rapido.

Appena ho tempo comunque lo leggo tutto
ciao.

p.s.:

if(top - f ==0)
return true;
else
return false;

per chiarezza ti conviene sostituirlo con:

return top == f;

Ultima modifica di end.is.forever : 23-10-2004 alle 12:57.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2004, 03:09   #4
boysna
Senior Member
 
Iscritto dal: Mar 2004
Città: castel san giorgio(salerno)
Messaggi: 1218
il bello è questo. cioè sono inizializzati a -1 ma quando arrivano nei metodi sono stati modificati con altri valori che non dovrebbero generare l' "array out of bounds". In realtà ci sono metodi ke se vengono eseguiti su una determinata istanza della coda generano eccezioni ke ancora non ho messo, ma finora li ho eseguiti solo con input ke non dovrebbbero dare eccezioni eppure mi trovo sempre quell'eccezione lanciata davanti.

Aspetto altre notizie..
boysna è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2004, 10:09   #5
end.is.forever
Senior Member
 
Iscritto dal: Jul 2004
Messaggi: 1578
La correzione più semplice è questa
Codice:
    public stackqueue( int capacity )
    {
        this.capacity = capacity;
        primo_array = new Object [ capacity ];
        secondo_array = new Object [ capacity ];
    }
Dato che non settavi il campo capacity di stackqueue, rimaneva a 0.
Nel metodo inverti dove viene costruito un array di dimensione capacity quindi avevi un array di dimensione 0, da cui la array out of bounds.

Non so quale ambiente usi, comunque ti consiglio per risolvere questi piccoli errori in pochi secondi, di usarne uno che supporti il debug con la possibilità di valutare i valori delle variabili; in particolare ti consiglio Eclipse della IBM che trovi qui gratis.

In ogni caso ti conviene non dare mai per scontati i valori che ti vengono dati come parametri, ne i campi di una classe, sempre per essere più efficiente nel debugging.

Ciao.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
Old 24-10-2004, 10:28   #6
end.is.forever
Senior Member
 
Iscritto dal: Jul 2004
Messaggi: 1578
Poi c'è un secondo errore dovuto al fatto che f era inizializzato a -1, e alla chiamata di pop da parte di dequeue scatena un'altra array out of bounds exception.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
Old 25-10-2004, 17:22   #7
boysna
Senior Member
 
Iscritto dal: Mar 2004
Città: castel san giorgio(salerno)
Messaggi: 1218
grazie x l'aiuto
ora l'eccezione non la lancia +..
xo il programma non è ancora perfetto..
ma questa volta credo d potercela fare senza aiuto, cmq uso jbuilder 6 dal momento ke il prof ha detto ke dobbiamo implementare con questo ambiente.....
boysna è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Italo fa la storia: Starlink arriver&agr...
Windows 11: rilasciati i fix di emergenz...
MacBook Air M4 in offerta su Amazon: il ...
Smartphone Motorola potenti a prezzi mai...
Dopo Las Vegas, Sphere raddoppia: in Mar...
Smarthome Tapo: funzionano bene, costano...
Valve aggiorna le linee guida Steam: chi...
PC portatili sempre più cari: ecc...
Samsung TV in offerta su Amazon: Neo QLE...
Sì, c'è un display è...
Fast restart di Windows spiegato 30 anni...
Il mondo piange Gladys West, la matemati...
Tomb Raider: Catalyst, il cast si allarg...
Renault Group chiude un ottimo 2025: Dac...
A questo prezzo la Blink Mini è difficil...
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: 11:56.


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