Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-11-2010, 08: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, 10: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, 10: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, 16: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, 11: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, 11: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, 11: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, 12: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 12:15.
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 12: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, 13: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 14:09.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 14: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 14:20.
tylerdurden83 è offline   Rispondi citando il messaggio o parte di esso
Old 24-11-2010, 14: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, 15: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, 16: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


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
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: 00:33.


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