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-2007, 10:29   #1
NiLUS
Senior Member
 
L'Avatar di NiLUS
 
Iscritto dal: Jun 2001
Città: Pordenone
Messaggi: 1216
[JAVA] Jasper, Threads su JVM IBM

Rapida panoramica della situazione:
Sto usando Jasper per creare dei Reports via Java in ambiente Lotus Notes (quindi JVM della IBM).

Il codice è molto semplice, e sono riuscito a restringere il problema alla classe JRXmlDataSource, che non mi pare disponga di metodi particolari per chiuderla, terminarla o quant'altro. Nello specifico, sto usando il costruttore a cui passo un InputStream (chiuso più avanti).

Il messaggio d'errore è il seguente:

Codice:
Error cleaning up agent threads
In pratica dopo 4 o 5 esecuzioni la RAM si riempie e si scaturisce l'eccezione OutOfMemoryError.

Ho trovato sul sito IBM questa funzione che ritorna i thread attivi:

Codice:
	public static void dumptg (ThreadGroup tg) {
		// First, get our thread group
		if (tg == null) {
			// none specified, assume current thread group
			tg = Thread.currentThread().getThreadGroup();    
		}
       
		// display the threadgroup name and object id
		System.out.println("ThreadGroup "+tg.getName()+ ", objid = "+tg.hashCode());
       
		// display the threadgroup's number of active subgroups
		System.out.println("  subgroups  = "+tg.activeGroupCount());
       
		// get and display the number of active threads in this threadgroup and all subgroups
		int tcount = tg.activeCount();
		System.out.println("  total threads = "+tcount);
       
		// allocate an array big enough to hold the number of threads
		Thread[] arr = new Thread[tcount];
       
		// fill in the array with the active threads (include subgroups)
		int num = tg.enumerate(arr,true);
       
		// display how many were stored.
		System.out.println("\nThread Name, ThreadID, ThreadGroup");
       
		// display the name, id and owning threadgroup of each thread
		for (int i = 0; i<num; i++) {
			System.out.println(arr[i].getName()+", "+
				arr[i].hashCode()+", "+
				arr[i].getThreadGroup().getName());
			try {
				arr[i].join(5000);
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}
L'output che mi torna, quando richiamata in ultimo prima del termine della funzione che utilizza la JRXmlDataSource è:

Codice:
ThreadGroup UTG: JavaAgent, objid = 127294134
  subgroups  = 0
  total threads = 2

Thread Name, ThreadID, ThreadGroup
AgentThread: JavaAgent, 14883511, UTG: JavaAgent
Questo alla prima esecuzione. All'output di cui sopra segue il "Error cleaning up agent threads". In una esecuzione successiva (senza chiudere e riaprire Lotus) mi dice che il numero totale di thread è pari a 1, anziché 2.

I sorgenti Java in Lotus differiscono un po' dagli standard. Funzionano in questo modo:

Codice:
public class JavaAgent extends AgentBase {
	public void NotesMain() {
		try {
			...
		}
		catch (Exception e) { e.printStackTrace(); }
	}
}
Ho provato a terminare il Thread manualmente (destroy), o con il join a dargli qualche secondo di tempo, ma l'errore persiste.

Non so se possa centrare, ma per far girare il tutto nella JVM di IBM ho dovuto aggiungere al java.policy, nel grant:

Codice:
	permission java.lang.RuntimePermission "createClassLoader";
	permission java.lang.RuntimePermission "getProtectionDomain";
Siccome Jasper sfrutta il ClassLoader per generare i report, anche se non è la JRXmlDataSource a richiedere il ClassLoader bensì la JasperRunManager.

Qualche idea? Il sorgente simile (dico simile perché senza AgentBase) eseguito su JVM Sun non mi crea di questi problemi, e non ho dovuto mettere mani alle autorizzazioni del ClassLoader. Che dipenda da questioni di sicurezza? Magari è necessario mettere mani ai permessi per "autorizzare" la JVM a terminare determinati Thread?

Provando ad aggiungere:

Codice:
	permission java.lang.RuntimePermission "stopThread";
	permission java.lang.RuntimePermission "modifyThreadGroup";
	permission java.lang.RuntimePermission "modifyThread";
Al java.policy ma nulla cambia.

Grazie in anticipo.
Ciao.
NiLUS è 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, ...
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...
I coupon nascosti di Amazon si rinnovano...
Disponibili i video e le immagini in alt...
La NASA ha rilasciato le prime fotografi...
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: 15:33.


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