Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-03-2006, 17:15   #1
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
[JAVA] Da HashMap a TreeMap

Nuovo esercizio
Dopo aver riempito la HashMap (vedi post QUI) , mi ritrovo con questa HashMap composta da coppie (frequenza, parola), cioè la frequenza in cui una parola appare in un file .txt.

Ora io dovrei formare delle nuove coppie (x,y) da stampare su file, cioè dove x parole compaiono esattamente y volte.
Devo scrivere un metodo

Codice:
Iterator count(Iterator it)
che riceve un iteratore sui valori della Map h e rende un iteratore sull’ entrySet() di una nuova Map, una TreeMap, che contiene le coppie (x, y).

Allora, io ho scritto questo codice:

Codice:
public static Map m=new HashMap(500);
.....
public static Iterator count(Iterator itr) {
     Map tree=new TreeMap();
     while (itr.hasNext()) {
         Object k = itr.next();
         if (!tree.containsValue(m.get(k))) tree.put(new Integer(1),m.get(k));
         else {
              int val=Integer.parseInt((tree.get(k)).toString());
    	      tree.put(new Integer(val+1),m.get(k));
    	 }
      } 
      Set s=tree.entrySet();
      Iterator i = s.iterator();
      return i;
}
Il porblema è che mi dà una ClassCastException sull'istruzione in neretto.
Esattamente è questo il responso:

Quote:
java.lang.ClassCastException: java.lang.Integer
at java.lang.String.compareTo(Unknown Source)
at java.util.TreeMap.compare(Unknown Source)
at java.util.TreeMap.getEntry(Unknown Source)
at java.util.TreeMap.get(Unknown Source)
at metodi.count(metodi.java:148)
at metodi.index(metodi.java:88)
at metodi.main(metodi.java:48)
Exception in thread "main"
Non so proprio cosa fare, è da un po' che ci sto ragionando ma non vengo mai a capo di questo problema.
Qualcuno mi dà una mano?

thks
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 17:23   #2
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
mentre ci enso, hai provato senza il toString()?????
e poi, hai provato a fare il cast a stringa di quella cosa lì......
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 19:29   #3
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at Copia_di_metodi.count(Copia_di_metodi.java:148)
at Copia_di_metodi.index(Copia_di_metodi.java:88)
at Copia_di_metodi.main(Copia_di_metodi.java:48)
Press any key to continue...

tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:16   #4
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da tagibo
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at Copia_di_metodi.count(Copia_di_metodi.java:148)
at Copia_di_metodi.index(Copia_di_metodi.java:88)
at Copia_di_metodi.main(Copia_di_metodi.java:48)
Press any key to continue...

sorry, ma quale caso, cast a stringa o senza toString
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:21   #5
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
scusa, mi fai un riassunto della classe che inserisce nella map please.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:34   #6
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da franksisca
sorry, ma quale caso, cast a stringa o senza toString
Ho provato entambi i casi, ma non ne va uno ..... Ti ho postato quello del cast....
Quote:
Originariamente inviato da franksisca
scusa, mi fai un riassunto della classe che inserisce nella map please.
Cmq la classe dell'inserimento nell'hash dovrebbe essere corrtta, il suo lavoro lo fa benissimo!! Eccola qui:
Codice:
public static void addHash(Map map, StringTokenizer s) {
	String str = "";
        //ciclo su s per aggiungere parole alla tabella hash
	while (s.hasMoreTokens()) {
		str = s.nextToken();
		//converto tutte le parole in minuscolo per non avere problemi 
		//con i codici hash
		str = str.toLowerCase();
		if (!map.containsKey(str)) map.put(str,new Integer(1)); //aggiungo
		else { //incremento
			Integer i = (Integer) map.get(str);
			map.put(str,new Integer(i.intValue() + 1));
		}
	}
	System.out.println(map.toString());
}
Ciao!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:38   #7
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:50   #8
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da pinok
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
arguto....... effettivamente non ci avevo pensato.......
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:11   #9
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da pinok
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at metodi.count(metodi.java:148)
at metodi.index(metodi.java:88)
at metodi.main(metodi.java:48)
Press any key to continue...

Non è possibile!!!
Non ne va bene una, sarà la quindicesima...
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:22   #10
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
L'istruzione che genera l'eccezione è:

tree.get(k)

Stando alla traccia, il tuo "k" risulta essere un tipo String mentre le chiavi del TreeMap sono di tipo Integer.

Ciao.

Ultima modifica di PGI-Bis : 17-03-2006 alle 21:38. Motivo: c'era una z di troppo in eccezione
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:46   #11
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da PGI-Bis
L'istruzione che genera l'eccezione è:

tree.get(k)

Stando alla traccia, il tuo "k" risulta essere un tipo String mentre le chiavi del TreeMap sono di tipo Integer.

Ciao.
Quindi cosa dovrei fare???
Ormai non ci capisco + nulla, scusami ma ho il cervello "in pappa"......
questo c***o di programma sta mettendo a dura prova la mia pazienza.....
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:59   #12
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Cancella tutto e, carta e penna alla mano (virtuali), scrivi la "prosa" di quello che vuoi fare. Quando la prosa è logicamente ineccepibile, la traduci in codice. Se la traduzione è esatta, il programma funzionerà.

Per ogni parola nel testo, sai quante volte quella parola compaia nel testo e devi stabilire quante parole appaiano 1 volta, se ce ne siano, 2 volte, se ce ne siano, 3 volte... n volte.

Ho inteso correttamente?
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:04   #13
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
scusa, ma equals e compareTo della classe che utti, li hai dfatti???
il get delle map riceve un object, quindi fa la ricerca nella lista in base a quei metodi. quindi, vedi tu e poi facci saere.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:16   #14
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Stando a quanto detto, mi pare di capire che i dati trattati siano String e Integer. Entrambi sono Comparable, ma, per sintetizzare con la sintassi di Java 5, uno è "Comparable<String>" e l'altro è "Comparable<Integer>", sebbene la vecchia versione di Java non consentisse di esprimerlo durante la compilazione (da cui il ClassCastException).

Un TreeMap che usi l'ordine naturale degli elementi (cioè le cui chiavi siano Comparable) richiede in estrazione un "compareTo" all'argomento del metodo get invocato.

Se k è String, allora è come se si invocasse

[String] compareTo [Integer]

da cui il segnale:

ClassCastException
java.lang.String.compareTo

Non è un problema di mancanza di metodi di comparazione ma di comparazione tra elementi incompatibili che deriva da una svista nella traduzione dal ragionamento che ha fatto tagibo dopo aver capito come si sarebbe potuto fare.

La scelta dell'uso dell'ordine naturale è perfettamente lecita e anche sensata se i dati siano, come sono, interi e stringhe.
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 23:25   #15
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da PGI-Bis
Stando a quanto detto, mi pare di capire che i dati trattati siano String e Integer. Entrambi sono Comparable, ma, per sintetizzare con la sintassi di Java 5, uno è "Comparable<String>" e l'altro è "Comparable<Integer>", sebbene la vecchia versione di Java non consentisse di esprimerlo durante la compilazione (da cui il ClassCastException).

Un TreeMap che usi l'ordine naturale degli elementi (cioè le cui chiavi siano Comparable) richiede in estrazione un "compareTo" all'argomento del metodo get invocato.

Se k è String, allora è come se si invocasse

[String] compareTo [Integer]

da cui il segnale:

ClassCastException
java.lang.String.compareTo

Non è un problema di mancanza di metodi di comparazione ma di comparazione tra elementi incompatibili che deriva da una svista nella traduzione dal ragionamento che ha fatto tagibo dopo aver capito come si sarebbe potuto fare.

La scelta dell'uso dell'ordine naturale è perfettamente lecita e anche sensata se i dati siano, come sono, interi e stringhe.
quello che intendevo io, ma siccome ho sempre preso 2 in italiano..........
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2006, 03:26   #16
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Io proverei a fare subito il cast dell'oggetto k quando lo tiri fuori, personalmente non mi piace molto girare con oggetti "indefiniti" quando posso farne a meno

Riguardando il codice e se l'ho capito bene, è cannato
Io ho capito che k è la tua parola e vuoi contare quante volte si ripete.
In questo caso dovresti usare k come chiave e come valore il numero di ripetizioni.

Invece tu controlli che non ci sia k come valore (e va bene presumendo che k sia unico per una precedente elaborazione, ma credo sia più lento perché ti perdi l'ottimizzazione sulle chiavi)

tree.containsValue(m.get(k))

e poi scrivi come nuova chiave il numero di ripetizione e ancora k come valore

tree.put(new Integer(val+1),m.get(k));

Ma qua sbagli, infatti stando alla descrizione del metodo:
Associates the specified value with the specified key in this map. If the map previously contained a mapping for this key, the old value is replaced.

In prima approssimazione ti dovresti trovare un tree con un solo elemento, con chiave 1 e valore l'ultima parola, perché tutte le volte che vai a scrivere che hai trovato un'occorrenza di quella parola in realtà aggiorni la chiave 1 con il valore pari alla parola analizzata.
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2006, 00:19   #17
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da pinok
Riguardando il codice e se l'ho capito bene, è cannato
Io ho capito che k è la tua parola e vuoi contare quante volte si ripete.
In questo caso dovresti usare k come chiave e come valore il numero di ripetizioni.
No, io non devo contare la frequenza di una parola, quello l'ho già fatto ed ho inserito tutto nella hashmap. Ora io devo estrarre tutto quello che c'è nella hashmap, fare tutti i controlli del caso e formare delle coppie (x,y) da stampare su file, dove x parole compaiono esattamente y volte.

se ad esempio in un file ho: mah beh mah forse non così non non cioè
l'output sarà: (4,1) (1,2) (1,3), cioè 4 parole appaiono 1 volta, 1 parola appare 2 volte ed 1 parola appare 3 volte.

Grazie delle risposte teoriche a tutti gli altri, ma io ora ho bisogno dell'istruzione corretta. Inutile che mi spiegate qualcosa, perchè nella condizione psicologica in cui sono adesso non capisco nulla!!

Speriamo che quando il programma funzionerà io sia tornato di nuovo "normale", ma ora solo aprire jCreator mi fa venire il mal di testa!!!

Grazie a tutti!!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2006, 00:59   #18
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17

GIRA ALLA PERFEZIONE!!!


Risolti tutti i problemi, funziona benissimo. Non ho più pensato al programma Sabato, Domenica e Lunedì; stamattina presto mi ci sono messo per bene, bello sveglio, nel silenzio, e in 20 min. andava tutto ok!! PERFETTO!!
Non chiedetemi cosa ho modificato perchè ero in trance, non mi ricordo nessuna intuizione avuta.... so solo che ora va!!!

Grazie a tutti!!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2006, 07:31   #19
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da tagibo

GIRA ALLA PERFEZIONE!!!


Risolti tutti i problemi, funziona benissimo. Non ho più pensato al programma Sabato, Domenica e Lunedì; stamattina presto mi ci sono messo per bene, bello sveglio, nel silenzio, e in 20 min. andava tutto ok!! PERFETTO!!
Non chiedetemi cosa ho modificato perchè ero in trance, non mi ricordo nessuna intuizione avuta.... so solo che ora va!!!

Grazie a tutti!!
facci vedere il codice finale, così vedremo tutti la soluzione.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Apple MacBook Neo 13'' con chip A18 Pro ...
Insieme a Leica SL3-P presentate le otti...
La Cina svilupperà anche il razzo...
Rocket Lab e la missione Victus Haze per...
Starship: Ship 40 ha eseguito uno static...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
389€ sono veramente pochi per questo PC ...
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: 19:33.


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