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 13-10-2006, 13:55   #1
elias86
Junior Member
 
Iscritto dal: Mar 2005
Messaggi: 7
AIUTO JAVA CONCORRENTE!!!

Ciao a tutti.
C'è questo bel progettino da consegnare entro lunedi alle 19... e faccio fatica a fare operazioni basilari come: far comunicare tutti i thread "avventore" con il "cameriere", impostare i tempi richiesti ecc.

vi allego il testo del progetto, sperando che qualche buona anima abbia voglia di darmi una mano!

grazie in anticipo a chiunque mi saprà dare una mano, Elias

ps:

per ora NON mi funziona questo:

In pratica stò cercando di inviare al Cameriere, le richieste di 5 Avventori (la richiesta è sotto forma di Stringa) che viene inviata al Cameriere. Il cameriere deve gestire una coda di richieste. Per maggiori info vedere l'allegato (TESTO COMPLETO).

Codice:
class Main {
	
	public static void main(String[]args) {
		String m1 = "O sole mio";
		String m2 = "Sucastaminchia!";
		String m3 = "Bad";
		String m4 = "Drop the bombshell";
		String m5 = "Just be";
		
		String wait = "wait";
		
		Cameriere cam = new Cameriere("wait");
		
		Avventore av1 = new Avventore(m1);
		Avventore av2 = new Avventore(m2);
		Avventore av3 = new Avventore(m3);
		Avventore av4 = new Avventore(m4);
		Avventore av5 = new Avventore(m5);
		
		av1.start();
		av2.start();
		av3.start();
		av4.start();
		av5.start();
		
		cam.start();
		
	}
}


public class Cameriere extends Thread{

	String canzone;

	public Cameriere(String canz) {
		canzone = canz.toString();
	}
	
	public String receive() {
		String ricevuta;
		
		synchronized(canzone) {
			if(canzone == null)
				ricevuta = null;
			else
				ricevuta = canzone.toString();
		}
		return ricevuta;
	}
	
	public void run(){
		String ricevuta;
		
		while(!isInterrupted()) {
			if((ricevuta = receive()) == null) {		
				try {
					sleep(1000);
				} 
				catch(InterruptedException e){
					return;
				}
			}
			System.out.println("\nCAMERIERE - canzone ricevuta: "+ricevuta);
		}
	}
}

public class Avventore extends Thread{

	String canzone;

	public Avventore(String canz) {
		canzone = canz.toString();
	}
	
	public void transmit(String canz) {
		synchronized(canzone){
			canzone = canz.toString();
		}
	}
	
	public void run(){
		int sleepTime = 50;
		
		System.out.println("\nAVVENTORE - canzone scelta: "+canzone);
		try {
			if(!isInterrupted()) {
				sleep(1000);
				transmit(canzone);
				if(isInterrupted())
					return;
				sleep(sleepTime*3);
			}
		} catch(InterruptedException e){}
		System.out.println("\nAVVENTORE - canzone inviata: "+canzone);
	}
}
elias86 è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 14:02   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ma il problema che ti da qual'è? semplicemente non funziona?

ps.non hai inserito il "TESTO COMPLETO"
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 15:27   #3
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
A meno che non mi sia sfuggita qualche variabile è tecnicamente impossibile che i tuoi Avventori ed il Cameriere possano interagire in un qualsiasi modo: non c'è alcun "valore condiviso" tra cam, av1, av2, av3, av4, e av5.

Dovete fare un esercizio sulla "meccanica della concorrenza" (neologismo ) nel linguaggio di programmazione Java oppure lo scopo è quello di realizzare un programma che faccia uso di più Thread? E, soprattutto, vi è stato spiegato qualcosa del supporto che il linguaggio Java offre alla programmazione concorrente o siete stati lanciati allo sbaraglio?
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 16:06   #4
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Quote:
Originariamente inviato da PGI-Bis
A meno che non mi sia sfuggita qualche variabile è tecnicamente impossibile che i tuoi Avventori ed il Cameriere possano interagire in un qualsiasi modo: non c'è alcun "valore condiviso" tra cam, av1, av2, av3, av4, e av5.

Dovete fare un esercizio sulla "meccanica della concorrenza" (neologismo ) nel linguaggio di programmazione Java oppure lo scopo è quello di realizzare un programma che faccia uso di più Thread? E, soprattutto, vi è stato spiegato qualcosa del supporto che il linguaggio Java offre alla programmazione concorrente o siete stati lanciati allo sbaraglio?
Sembra voglia implementare il tutto con i metodi transmit e receive. Ora provo a compilarlo e do' un'occhiata.
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 16:31   #5
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Il programma non funziona semplicemente perchè non hai implementato alcun meccanismo di sincronizzazione tra i thread.
Prima di tutto ti consiglio di implementare una classe che funge da oggetto condiviso, a cui gli avventori (produttori) ed il cameriere (consumatore) accedono in modo mutualmente esclusivo.
E' un classico problema produttore-consumatore: onestamente ho modificato il tuo codice affinche funzioni, ma non mi sembra corretto postarlo sennò dubito che impari qualcosa I suggerimenti sono benvenuti invece.
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 16:34   #6
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
In verità ho peccato di avventatezza. Qualcosa di condiviso c'è. E' persino qualcosa di usabile per sincronizzare dei Thread. Ma, non so perchè, dubito che sia stato contemplato durante la scrittura del programma.
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 17:08   #7
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Quote:
Originariamente inviato da PGI-Bis
In verità ho peccato di avventatezza. Qualcosa di condiviso c'è. E' persino qualcosa di usabile per sincronizzare dei Thread. Ma, non so perchè, dubito che sia stato contemplato durante la scrittura del programma.
Sì, fondamentalmente la sua versione non funziona perché non c'è un oggetto condiviso a cui produttpri e consumatori accedono. Lui usa la keyword "synchronized" su una variabile non static, non funzionerà mai. O rende la variabile static (variabile di classe), oppure (mooolto meglio) fa una piccola classe ad hoc con due metodi synchronized (tipo get e put) che gestiscono (in automatico) la mutua esclusione nell'accesso all'oggetto.
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 22:20   #8
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Per Brinch Hansen e C. A. R. Hoare si staranno rivoltando nella tomba

cerca in giro esempi di monitor o semafori....vedi che n on è molto difficile, se hai problemi chiama
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 23:00   #9
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Quote:
Originariamente inviato da franksisca
Per Brinch Hansen e C. A. R. Hoare si staranno rivoltando nella tomba

cerca in giro esempi di monitor o semafori....vedi che n on è molto difficile, se hai problemi chiama
Hoare è ancora vivo. Per Hansen non ti so dire. Ha già un mutex (rientrante). Non gli servono nè i semafori nè i monitor.
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 23:25   #10
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da PGI-Bis
Hoare è ancora vivo. Per Hansen non ti so dire. Ha già un mutex (rientrante). Non gli servono nè i semafori nè i monitor.


avevo proposto il monitor solo per avere un gestore della situazione, visto che manca qualcosa da condividere.......
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2006, 07:16   #11
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Basta una classe aggiuntiva (piccolissima) che faccia da pool di dati, con 2 metodi definiti "synchronized": get() e put(). Il pool può contenere un solo dato o più di uno, l'importante è che la classe abbia un flag che, nel caso indichi buffer pieno, mette i thread in wait() fino a quando qualcuno non fa notifyAll() (sempre all'interno dell'oggetto). Insomma, implementare una sezione critica per condividere dei dati.
Ripeto, avrei modificato il programma per farlo funzionare in questo modo, al limite posto solo il codice della classe condivisa, postare tutto mi sembra non didattico (che poi è lo scopo di elias86 mi pare imparare java )
Ah, ovviamente il main istanzia (crea con new...) UN oggetto condiviso, che viene passato nel costruttore di tutti i thread (sia gli avventori-produttori che il "cameriere"-consumatore)per essere usato. Non è che tutti i thread devono creare un'istanza dell'oggetto condiviso, altrimenti non sarebbe più condiviso

EDIT: Non c'è bisogno né di semafori né di altro in questo caso, bastano i metodi "synchronized" di una classe istanziata come oggetto condiviso, poi fa tutto java. Se poi si vuole un meccanismo di segnalazione o altro, ci sono altre strutture dati come i semafori, ma non mi pare questo sia il caso onestamente (meglio che elias86 impari una cosa alla volta)

EDIT 2: in effetti meglio postare almeno il codice della classe condivisa, così che possa essere esaminato:

Codice:
public class DataPool {
	private String data;
	private boolean available;
	
	public DataPool()
	{
		this.data = null;
		this.available = false;
	}
	
	public synchronized String get()
	{
		while (available == false) {
            		try {
                		wait();
            		} catch (InterruptedException e) { }
        	}
        	available = false;
        	notifyAll();
        	return data;
	}
	
	public synchronized void put(String data)
	{
		while (available == true) {
            		try {
                		wait();
            		} catch (InterruptedException e) { }
        	}
		if (this.data == null)
			this.data = new String;
		this.data = data;
        	available = true;
        	notifyAll();
	}
}
Se si vuole contenere più di una stringa (o qualunque altro tipo di dato...), basta sostituire il flag booleano con un intero contatore, e fare una cosa del tipo
Codice:
while (counter >= DIM_MAX) //DIM_MAX è la dimensione dell'array dei dati
{
        try...
Inoltre, per il suo caso, ho modificato questa classe così, in modo da contenere anche il nome del thread oltre alla canzone (sennò non si sa quale thread ha messo il dato nel pool):

Codice:
public class DataPool {
	private String[] data;
	private boolean available;
	
	public DataPool()
	{
		this.data = null;
		this.available = false;
	}
	
	public synchronized String[] get()
	{
		while (available == false) {
            		try {
                		wait();
            		} catch (InterruptedException e) { }
        	}
	        available = false;
        	notifyAll();
        	return data;
	}
	
	public synchronized void put(String threadId, String data)
	{
		while (available == true) {
            		try {
                		wait();
            		} catch (InterruptedException e) { }
        	}
		if (this.data == null)
			this.data = new String[2];
		this.data[0] = threadId;
		this.data[1] = data;
        	available = true;
        	notifyAll();
	}
}
Sono abituato ad usare i nomi di metodi, classi, variabili ecc. in inglese, non me ne vogliate
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson

Ultima modifica di -fidel- : 14-10-2006 alle 07:38.
-fidel- è 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...
Deezer ha rilasciato un tool gratuito pe...
AMD Ryzen 9 7950X3D danneggiato: approva...
I Mac con chip Apple Silicon hanno meno ...
Scandalo nel Regno Unito: agente sotto i...
TOP 15 offerte Amazon del weekend: 10 tu...
DJI Neo Fly More Combo a 245€: il mini d...
JBL Live Beam 3 a 129€ invece di 199€ su...
L'FBI ha costruito una città segr...
AMD usa il MacBook Neo come bersaglio in...
Intel prepara 'Raptor Lake Next'? Nel 20...
Una telefonata del CEO di Amazon dietro ...
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...
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: 12:15.


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