Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-05-2011, 11:35   #1
Sprizzy
Junior Member
 
L'Avatar di Sprizzy
 
Iscritto dal: May 2011
Messaggi: 8
[JAVA] Problema StackOverFLow

Ciao a tutti,
ho scritto un programma in java in cui vi sono 3 metodi che si richiamano ricorsivamente in questo ordine:
1-->2-->3-->1-->2... ecc e fin qui non ho riscontrato alcun problema(ma così è incompleto).
Il programma completo consta di 4 metodi che si dovrebbero richiamare così:
1-->2-->3-->4-->1-->2 .. ecc.
Ora mi da stackOverflowerror ... ho pensato che il programma andasse in crash a causa di una ricorsione infinita. Così ho creato una variabile che si decrementa ogni volta che il 4 metodo viene richiamato,per vedere se mi dava lo stesso errore pur facendolo eseguire un numero n finito di volte. Questo programma l'ho fatto girare su più pc.. su alcuni da errore cmqe su altri no. Ho provato a mettere come opzione in esecuzione java nome -Xmx512m ..ma niente!
In determinati istanti n=10000 per esempio va bene... ma in altri lo devo decrementare altrimenti mi ridà stackOverFlowerror!!
...
Il programma apre un file di testo di circa 20 mega e memorizza i dati in un array che viene elaborato nei metodi.
So disperata!

Ultima modifica di Sprizzy : 06-05-2011 alle 11:40.
Sprizzy è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 12:08   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Domanda: se in esecuzione la virtual machine lancia uno StackOverflowError, tu sai cosa significa?
Indizio: la dumentazione descrive StackOverflowError così:
Quote:
Thrown when a stack overflow occurs because an application recurses too deeply.
Quote:
Ho provato a mettere come opzione in esecuzione java nome -Xmx512m ..ma niente!
La memoria heap è diversa dallo stack.
Le istanze create con new vengono allocate nella memoria heap.
Quindi aumentare lo heap può essere utile se il tuo programma alloca molte istanze o comunque esegue operazioni avide di ram.

Il "problema" nel tuo programma, a naso, è che esegui troppe chiamate ricorsive... troppe almeno per lo stack, che viene saturato tutto prima che il numero effettivo di chiamate ricorsive eseguite a runtime nel tuo programma venga espletato completamente.

Probabilmente doresti cercare di modellare la soluzione al tuo problema evitando di fare uso di così tante chiamate ricorsive.
Che problema stai cercando id risolvere con il tuo programma?
__________________

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 06-05-2011, 15:07   #3
Sprizzy
Junior Member
 
L'Avatar di Sprizzy
 
Iscritto dal: May 2011
Messaggi: 8
Il problema è che è l'algoritmo che richiede chiamate ricorsive.
E' inevitabile: con un metodo creo k matrici dove k=num nodi del grafo che elaboro poi se è verificATA UNA CERTA CONDIZIONE RICHIAMO IL METODO 3 CHE A SUA volta obbligatoriamente deve richiamare il 4 metodo che richiama il 1.In pratica io lavoro con un grafo... ogni elemento dell'array è un arco del grafo.
il lavoro consiste nell'eliminare ed aggiungere ricorsivamnte gli archi da grafo che ho creato leggendo il file di testo.
Non potrei organizzare il lavoro altrimenti, non posso cambiare l'algoritmo che mi è stato imposto di utilizzare.
Non conosco bene l'errore che mi da la jvm per questo chiedo aiuto... ad esempio potrei impostare da qualche parte l'utilizzo di una memoria dedicata all'esecuzione del programma più grande?? Altrimenti nn so proprio come risolvere... GRAZIE ))
Sprizzy è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 16:05   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Il problema è che è l'algoritmo che richiede chiamate ricorsive.
[cut]
1) In generale, un algoritmo ricorsivo può essere trasformato in uno iterativo.

2) Se non stai eseguendo un compito scolastico oppure se hai carta bianca nell'implementare la tua soluzione, per Java, esistono JGraph/JGraphT, due librerie (tra le millemila) per lavorare con i grafi (la prima per la visualizzazione grafica, la seconda per algoritmi e strutture dati associate).

3) Se ci spieghi cosa devi fare di preciso con questi grafi magari salta fuori che ti servono uno o più algoritmi già esistenti che magari devi solo "piegare" un po' alle tue esigenze specifiche (in JGraph sono già presenti delle implementazioni di detti algoritmi e/o trovi dei "componenti" da usare per costruire i tuoi algoritmi).
In ogni caso, nell'implementare la soluzione bisogna tenere conto della tecnologia/linguaggio/strumento che si sta usando.
Se il tuo algoritmo, così com'è, sta saturando lo stack a furia di chiamate ricorsive, potrà anche rappresentare, sulla carta, una soluzione teorica corretta del problema ma ovviamente non va bene in pratica, ergo devi trovare un'altra strada.
__________________

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 : 06-05-2011 alle 16:07.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 16:49   #5
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Prova ad aumentare la dimensione dello stack. Non so quale sia la dimensione predefinita ma ho letto che 128k è normale, 2 megabyte è gigantesca. Il comando è "-Xss" seguito dalla dimensione

java -Xss512k il main
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 17:44   #6
Sprizzy
Junior Member
 
L'Avatar di Sprizzy
 
Iscritto dal: May 2011
Messaggi: 8
Allora il programma fa le seguenti cose:
Legge un file di testo di circa 20 mega.
Ogni riga la salvo in un oggetto arco dell'array.
L'oggetto arco ha dei campi:
coda testa popolazione costo pixel servito
la coda e la testa rappresentano i nodi.
Grafo base()
{Prende in ingresso l'array di archi e confronta quelli paralleli(stessa testa e coda), l'arco con il costo minore verrà memorizzato anche in un nuovo array piu piccolo. Mentre gli altri rimangono cmqe nel vecchio array.
}
MatriceD(){
Crea una matrice dove in posizione i,j vi è un costo molto elevato e in pos i,i costo 0... per l'algoritmo è la matrice iniziale.}
Floyd(){
crea k matrici con k=num di nodi del grafo. in ogni matrice k sostituisce in posizione i,j e i,i il costo se e solo se il percorso nuovo da i a j costa meno del precedente. ad esempio se sto in matrice k=3 io posso utilizzare per arrivare da uyn qualsiasi nodo i,j solo gli archi 1 2 e 3 e cosi via. infine qst metodo controlla se in pos i,i vi è un costo<0. se vero si avvia il metodo seguente(cicloN) altrimenti da un risultato(ossia quanta popolazione viene servita).. con elementi i,i negativi non si avrebbe una soluzione ammisibile.}
cicloN(){
Trova il cammino, cioè i nodi, attrtaversati per arrivare dal nodo i al nodi i stesso(bisogna controllare solo la positività degli alementi della diagonale principale). una volta risaliti al ciclo negativo si elimina un arco del ciclo secondo un criterio(costo minimo)}
..
Questo è il metodo che mi da problemi..
NuovoGB(){
ho la posizione in grafo base dell'arco eliminato ed in tale posizione provo a riaggiungere un arco a lui parallelo che si trova nel vecchio array(per servire + popolazione possibile). Ovviamente gli archi eliminati nn verranno piu ripescati sennò il programma nn terminerebbe mai...
}
ora si richiama matriceD...
il programma termina quando in floyd nn si trovano piu elementi <0 sulla diagonale principale...
Sprizzy è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 18:53   #7
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 13000
Sei sicura che hai implementato correttamente l'algoritmo?

La prima cosa da fare in questi casi è controllare se hai specificato correttamente la condizione base per la quale esci dalla ricorsione.

Inoltre ti suggerisco di provare prima con un set di dati più piccolo, in modo da facilitare anche il debug.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2011, 19:02   #8
Sprizzy
Junior Member
 
L'Avatar di Sprizzy
 
Iscritto dal: May 2011
Messaggi: 8
Sì sì certamente ho lavorato con file moto più piccoli e non da' errore.
Inoltre ho messo la condizione di cui parli...
Sprizzy è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2011, 18:09   #9
Sprizzy
Junior Member
 
L'Avatar di Sprizzy
 
Iscritto dal: May 2011
Messaggi: 8
Vi ringrazio... alla fine ho risolto!
Sprizzy è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Grazie a GLIMPSE-17775 il telescopio spa...
Samsung Galaxy A27 5G è ufficiale...
TCL aggiorna la sua gamma di monitor per...
Anche OPPO avrà uno smartphone co...
La Radeon RX 9070 XT appare su Steam e m...
L'America si ribella ai datacenter: bloc...
'Artificial General Engineer': l'IA di J...
Il drone NASA Dragonfly, che voler&agrav...
Stop immediato a Fable 5 e Mythos 5: il ...
"Prime Day Amazon il 23-26 giugno": sì e...
Oggi 2 super MacBook Pro M5 e M5 Pro, 24...
Tineco Floor One Station S9 Artist: il s...
Raggiunte nuove altitudine e velocit&agr...
Apple Watch Series 11 GPS a 339€ su Amaz...
Come un MacBook, ma con la RTX 5070: MSI...
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: 01:53.


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