Torna indietro   Hardware Upgrade Forum > Software > Programmazione

FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 porta il Wi-Fi 7 dual-band nelle case connesse. Mette a disposizione fino a 2.880 Mbit/s su 5 GHz e 688 Mbit/s su 2,4 GHz, integrazione Mesh immediata via WPS con FRITZ!Box e funzioni smart come MLO per bassa latenza. Compatto, plug-and-play e pronto per il futuro, è la soluzione ideale per chi vuole coprire ogni angolo senza cavi o complicazioni
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
La Fondazione Chips-IT ha presentato a Pavia il piano strategico 2026-2028 per rafforzare l'ecosistema italiano dei semiconduttori. Con un focus su ricerca, design, talenti e infrastrutture, la Fondazione punta a consolidare il ruolo dell'Italia nel Chips Act europeo, sostenendo innovazione, collaborazione industriale e sovranità tecnologica.
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud
Al Museo Alfa Romeo di Arese, Nutanix ha riunito clienti, partner ed esperti per .Next On Tour Italia e per mostrare come l’infrastruttura hybrid multicloud possa diventare il fondamento dell’innovazione, con una piattaforma capace di unificare applicazioni tradizionali, moderne architetture cloud-native e nuovi scenari basati sull’intelligenza artificiale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-10-2006, 14: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, 15: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, 16: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, 17: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, 17: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, 17: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, 18: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, 23: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 14-10-2006, 00: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 14-10-2006, 00: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, 08: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 08:38.
-fidel- è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica Fondazione Chips-IT, l'Italia alla riscossa nei ...
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Due mesi di Battlefield 6: dalla campagna al battle royale, è l'FPS che stavamo aspettando Due mesi di Battlefield 6: dalla campagna al bat...
Occhio ai prezzi dei robot ECOVACS Deebo...
IQM investe 40 milioni di euro per espan...
Truffa via email sfrutta PayPal: notific...
SPHBM4, una 'nuova' memoria all'orizzont...
L'IA sta rimodellando il Web. Come? Lo s...
Gen.Urban, a Wolfsburg iniziano i test s...
La Svezia è il primo Paese a lanc...
Star Wars: Fate of the Old Republic usci...
Addio guerra dei prezzi? La Cina pubblic...
La RTX più folle mai progettata? ...
Nell'infinita saga di Fast and Furious c...
MSC Crociere vieta gli occhiali smart a ...
OpenAI, Codex e il "vibe engineerin...
Codex Mortis: il primo videogioco intera...
Peugeot rilancia il mitico 103 in versio...
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: 14:13.


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