Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-11-2010, 09:48   #1
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
[JAVA] Problema con custom classloader

Buongiorno a tutti. Sto cercando di scrivere un classloader custom (estende URLClassLoader) per caricare/ricaricare a runtime certe classi.

Ho provato in vari modi ma ho una serie di problemi. Ad esempio, non riesco a "collegare" correttamente il custom classloader alla gerarchia di classloader. In pratica, riesco a fargli caricare un jar a runtime, ma quando carico una classe specifica dentro quel jar mi va in ClassNotFoundException su classi che avrebbe dovuto trovare nei classloader padri (ad es org.apache.log4j)...

Qualcuno ha già dovuto sbattere la testa sui custom classloader e mi sa dare una mano?
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 23-11-2010, 11:31   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Non posso darti consigli circostanziati, perchè fin'ora non mi sono mai cimentato nello studio del meccanismo di class loading e nell'implementazione di un custom ClasslLoader, però prova a vedere se questa lettura aiuta:
http://books.google.com/books?id=EhX...loader&f=false
__________________

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 23-11-2010, 11:37   #3
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Non posso darti consigli circostanziati, perchè fin'ora non mi sono mai cimentato nello studio del meccanismo di class loading e nell'implementazione di un custom ClasslLoader, però prova a vedere se questa lettura aiuta:
http://books.google.com/books?id=EhX...loader&f=false
Ancora una volta ban è in soccorso! Grazie, vado a documentarmi!
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 23-11-2010, 17:08   #4
euks
Junior Member
 
Iscritto dal: Jul 2007
Città: Benevento
Messaggi: 18
Se estendi URLClassLoader basta passare il classloader padre al costruttore
__________________
Pocket-MAL - MyAnimeList on iPhone - euks.wordpress.com
PC1 - Thermaltake V4 | Corsair TX 650M | ASRock Z77 Extreme 6 | 3770K | 8GB G-Skill Sniper F3
PC2 - Cooler Master Centurion 534 | Enermax Liberty 500W | Gigabyte P35-DS4 | Intel Core2Duo E6600@3600 | 4GB Corsair Xms2 | Nvidia GeForce 8600GT | Seagate Barracuda 7200.10 320GB | LG H62N
euks è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 12:20   #5
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
Quote:
Originariamente inviato da euks Guarda i messaggi
Se estendi URLClassLoader basta passare il classloader padre al costruttore
Vero, ma ho comunque un problema, ossia il fatto che se una classe usata nella classe che carico dinamicamente è già stata caricata ottengo un classcastexception perchè la stessa classe caricata da due class loader diversi è diversa...
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 12:54   #6
euks
Junior Member
 
Iscritto dal: Jul 2007
Città: Benevento
Messaggi: 18
Strano. Mi è capitato più volte di fare in questo modo e non ho avuto problemi.
Potresti postare il codice?
__________________
Pocket-MAL - MyAnimeList on iPhone - euks.wordpress.com
PC1 - Thermaltake V4 | Corsair TX 650M | ASRock Z77 Extreme 6 | 3770K | 8GB G-Skill Sniper F3
PC2 - Cooler Master Centurion 534 | Enermax Liberty 500W | Gigabyte P35-DS4 | Intel Core2Duo E6600@3600 | 4GB Corsair Xms2 | Nvidia GeForce 8600GT | Seagate Barracuda 7200.10 320GB | LG H62N
euks è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 12:57   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da tylerdurden83 Guarda i messaggi
...perchè la stessa classe caricata da due class loader diversi è diversa...
Questo è esatto.
Ed è giusto che sia così per via di implicazioni inerenti la sicurezza, quando si caricano classi remote.
__________________

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 24-11-2010, 13:03   #8
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
La main class

Codice:
public static void main(String[] args) throws ClassNotFoundException, IllegalAccessException, InstantiationException {
    try {
        ClassLoader parentClassLoader = MyClassLoader.class.getClassLoader();
        MyClassLoader classLoader = new MyClassLoader(parentClassLoader);
        Class myObjectClass = classLoader.loadClass("monitor.resource.Resource");
        Resource object1 = (Resource) myObjectClass.getConstructor(String.class,String.class,String.class,boolean.class,String.class).newInstance("resourceFile","patternFile","resourceName",true,"parserClass");
				...
}
MyClassLoader:

Codice:
public class MyClassLoader extends URLClassLoader{

    public MyClassLoader(ClassLoader parent) {
        super(new URL[0],parent);
    }

    @Override
    public Class loadClass(String name) throws ClassNotFoundException {
        if(!"monitor.resource.Resource".equals(name) ){
                System.out.println("DELEGATING LOADING OF "+name+" TO PARENT CLASSLOADER");
                return super.loadClass(name);
        }
        try {
            if("monitor.resource.Resource".equals(name)){
                System.out.println("LOADING monitor.resource.Resource...");
                String url = "jar:file:C:\\Documents and Settings\\User15\\Documenti\\NetBeansProjects\\monitorv4.0.2\\dist\\monitorv4.0.2.jar!/";
                this.addURL(new URL(url));
                return this.findClass("monitor.resource.Resource");
            }
            ...
}
Lo stack trace:

Quote:
LOADING monitor.resource.Resource...
DELEGATING LOADING OF java.lang.Object TO PARENT CLASSLOADER
DELEGATING LOADING OF java.lang.String TO PARENT CLASSLOADER
Exception in thread "main" java.lang.ClassCastException: monitor.resource.Resource cannot be cast to monitor.resource.Resource
at varioustests.MyClassLoaderTest.main(MyClassLoaderTest.java:31)
Java Result: 1

Ultima modifica di tylerdurden83 : 24-11-2010 alle 13:15.
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 13:18   #9
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
Precisazione, il classCast (dovrebbe) essere dovuto appunto al fatto che monitor.resource.Resource era già stata caricata in precedenza in quanto contenuta in un jar che va necessariamente incluso nel classpath
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 14:00   #10
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Precisazione, il classCast (dovrebbe) essere dovuto appunto al fatto che monitor.resource.Resource era già stata caricata in precedenza in quanto contenuta in un jar che va necessariamente incluso nel classpath
Che io sappia il meccanismo di class loading è di tipo lazy: allo start-up la virtual machine non contiene nessuna classe caricata in memoria. Prima viene caricato il class file del programma in esecuzione, poi altre classi/interfacce vengono caricate man-mano che se ne incontra il riferimento nel bytecode in esecuzione.
Quindi in questo caso credo non sia sufficiente il fatto che la risorsa (file jar) in cui è contenuto il bytecode della classe in questione (monitor.resource.Resource) si trovi nel classpath per giustificarne il caricamento da parte del system class loader: deve essere già stato incontrato un riferimento nel codice eseguito prima dell'esecuzione di:
Codice:
...
Class myObjectClass = classLoader.loadClass("monitor.resource.Resource");

...
Nel codice che hai postato, prima di quella istruzione, ci sono riferimenti espliciti solo ai tipi Object, MyClassLoaderTest, String, ClassLoader, MyClassLoader e Class.
In base al mio ragionamento, andando per esclusione, gli unici candidati papabili sembrano essere MyClassLoaderTest e MyClassLoader.

@EDIT:
Qua trovi un articolo focalizzato (2003) sul meccanismo del class loading.

@RI-EDIT:
Altre due risorse che contengono ulteriori info (in una si parla pure di class unloading) e mi sembrano più complete
link1 link2
__________________

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 : 24-11-2010 alle 15:09.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 15:10   #11
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Quindi in questo caso credo non sia sufficiente il fatto che la risorsa (file jar) in cui è contenuto il bytecode della classe in questione (monitor.resource.Resource) si trovi nel classpath per giustificarne il caricamento da parte del system class loader: deve essere già stato incontrato un riferimento nel codice eseguito prima dell'esecuzione di:
E' vero. Tuttavia, nella MyClassLoaderTest (quella con il main), quando incontra:

Codice:
Resource object1 = ...
cerca Resource nel classpath e lo carica. Questo Resource, caricato dal classloader della classe MyClassLoaderTest è diverso dal Resource restituito dalle due righe subito sopra:

Codice:
MyClassLoader classLoader = new MyClassLoader(parentClassLoader);
Class<?> myObjectClass = classLoader.loadClass("monitor.resource.Resource");
Quindi quando faccio:

Codice:
Resource object1 = (Resource) myObjectClass.getConstructor(...);
ottengo il ClassCastException

Ultima modifica di tylerdurden83 : 24-11-2010 alle 15:20.
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 15:58   #12
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Sì, stiamo dicendo la stessa cosa, la mia era una precisazione (circa il discorso relativo ad avere o no il jar nel classpath ai fini del class loading).

L'errore è quello: hai già caricato una classe monitor.resource.Resource con il system classloader, quando poi carichi monitor.resource.Resource anche con il tuo custom classloader, esso internamente dovrebbe delegare normalmente al parent classloader anche il caricamento di questa classe, e solo se non la trova già caricata dal parent classloader si occupa lui di caricarla.

Negli esempi canonici di cui ho letto/ho visto io di estensione del class loader, di solito non si fa l'override del metodo loadClass, ma del metodo findClass (normalmente è il motivo principale per cui ci si scrive un proprio class loader, ti rimando alle risorse che ti ho linkato, in particolare l'estratto su google book).

A questo punto forse è meglio se ci spieghi cosa stai cercando di ottenere?
__________________

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 24-11-2010, 16:22   #13
tylerdurden83
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 691
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
hai già caricato una classe monitor.resource.Resource con il system classloader, quando poi carichi monitor.resource.Resource anche con il tuo custom classloader, esso internamente dovrebbe delegare normalmente al parent classloader anche il caricamento di questa classe, e solo se non la trova già caricata dal parent classloader si occupa lui di caricarla.
Questo è il motivo per cui ho override loadclass invece di findclass. L'obiettivo è quello di ricaricare delle classi, che a loro volta potrebbero usare internamente una nuova classe non ancora caricata / presente nel classpath e quindi che va caricata da zero.

Se faccio come dici e cioè caricare una classe solo se nn la trova gia caricata dal parent classloader posso ottenere il secondo target (caricare classi non ancora caricate), ma non ricaricare "a caldo" una classe modificata (la cui versione precedente era gia stata caricata)
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 17:17   #14
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da tylerdurden83 Guarda i messaggi
...
Se faccio come dici e cioè caricare una classe solo se nn la trova gia caricata dal parent classloader posso ottenere il secondo target (caricare classi non ancora caricate), ma non ricaricare "a caldo" una classe modificata (la cui versione precedente era gia stata caricata)
Infatti, da quel che ho letto (e ancora una volta devo sottolineare la mia mancanza di esperienza diretta con il meccanismo di class loading, perchè tu ne devi essere consapevole e rpendere cum grano salis quello che ti dico) le due cose che vuoi fare sono appunto due cose diverse.

Questo perchè una classe XYZ, una volta che è stata caricata viene tenuta in cache; se al class loader chiedi di "ricaricarla" esso non la ricarica, la pesca dalla cache.

Bisogna quindi vedere se (e come) è possibile scaricare una classe già caricata da un class loader, in generale; e poi nello specifico (se nel tuo caso sarà per forza di cose il system class loader quello coinvolto con il caricamento delle classi in questione) se e come scaricare una classe dal system class loader.
__________________

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
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
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
GTA 6 gratis se nasce un figlio il giorn...
Quasi la metà degli smartphone at...
DDR5 a 16 dollari al gigabyte: Framework...
Meno di 3kg per 'diventare' bionici: l'u...
Al regalo di San Valentino ci pensa HUAW...
Intel multata in India: 30 milioni di do...
Beast of Reincarnation ha una data di us...
Provati Reno15 e Reno15 FS: analisi comp...
L'Europa sfida la Cina sul litio: in Fin...
Sono 32, di cui 6 nuove, le offerte Amaz...
Rinnovo dei coupon Amazon nascosti: ecco...
Corsair aggiorna la confezione delle RAM...
Ecco tutti i robot aspirapolvere in offe...
Tachyum: dal processore universale alle ...
L'eVTOL tedesco per missioni mediche e m...
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: 20:47.


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