Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-07-2008, 21:26   #1
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
[java] help elaborato

Ciao a tutti ragazzi ho bisogno di voi... oggi il prof mi ha voluto assegnare un elaborato java che consiste in questo:
c'è una strada a doppio senso ma a un certo punto c'è una strettoia e possono passare le macchine in unico senso e per di più entro questa strettoia c'è la limitazione che + di "n" macchine non ci possono passare!
Chiaramente devo evitare deadlock e starvation!
ora mi chiedevo: meglio usare i metodi syncronized oppure i semafori?
considerate ragazzi che non ho mai fatto programmazione a oggetti quindi se avete anche delle dispense mi farebbero comodo, ho scaricato il manuale gratuito java ma...
il top sarebbe eseguirlo graficamente! che mi dite?
grazie in anticipo
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 07:30   #2
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
Ciao!

Quote:
Originariamente inviato da Solido
oggi il prof mi ha voluto assegnare un elaborato java che consiste in questo:
c'è una strada a doppio senso ma a un certo punto c'è una strettoia e possono passare le macchine in unico senso e per di più entro questa strettoia c'è la limitazione che + di "n" macchine non ci possono passare!
Chiaramente devo evitare deadlock e starvation!
ora mi chiedevo: meglio usare i metodi syncronized oppure i semafori?
So che non si risponde con una domanda...ma visto che è una cosa didattica, non è che forse hai studiato le primitive wait e notify???Se la risposta è affermativa, perchè allora non implementare quelle? Intendo dire che per la gestione della acquisizione e rilascio della risorsa condivisa (la strettoia del ponte) secondo me ti devi proprio scordare delle librerie!


Quote:
Originariamente inviato da Solido
ho scaricato il manuale gratuito java ma...
il top sarebbe eseguirlo graficamente! che mi dite?
grazie in anticipo
Ti dico che se hai appena scaricato il manuale gratuito ma ....beh allora forse ti conviene farlo testuale e amen.
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 12:39   #3
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
si ho fatto il wait e notify
tra l'altro usassi il notify non importerebbe mica usare il notify all?
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 13:31   #4
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
no no....tu intendi il metodo della classe Object???

Io ti dicevo proprio di implementarlo per conto tuo...per esempio la wait:

Codice:
public void wait(int semaforo) {
    while(semaforo <= 0) {
        ; // non fa niente
    }
    semaforo--;
}
e la signal:

Codice:
public void signal(int semaforo) {
    semaforo++;
}
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 13:44   #5
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
ahh ok

il top sarebbe fare anche un'animazione solo che nn so da che parte rifarmi...che dici? è impossibile?
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 16:51   #6
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
Quote:
Originariamente inviato da Solido
il top sarebbe fare anche un'animazione solo che nn so da che parte rifarmi...che dici? è impossibile?

impossibile non è!!!però trovo già di per se abbastanza complicato integrare al programma vero e proprio, l'interfaccia utente e/o la grafica. In questo caso rischi di impelagarti in situazioni tipo:

"La grafica riproduce fedelmente il problema - qui non sembra funzionare niente - il problema deve essere l'implementazione del programma"

quando invece già la grafica ha i suoi problemi di gestione.

Cmq se proprio vuoi un punto da cui partire, inizia dal tutorial java della sun e vai al trail "gui with JFC/SWING" (o una cosa del genere) e poi vai giù di fantasia!!! (sicuramente c'è più di un valido modo per produrre qualcosa di graficamente accettabile)
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2008, 17:20   #7
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
penso che mi limiterò all'implementazione del solo programma ammesso mi riesca dato che non ci metto le mani
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
Old 28-08-2008, 20:09   #8
Solido
Senior Member
 
L'Avatar di Solido
 
Iscritto dal: Jan 2004
Città: Figline(FI)
Messaggi: 5847
Ragazzi ho terminato l'elaborato ma mi manca una cosa... una volta terminato volevo che comparisse la scritta: le macchine non possono + passare perchè i ponte è crollato....solo che non la inserisco nel punto giusto e mi compare + di una volta...
questo è il codice:
(nn fate caso al commento del try catch che era na prova )


Codice:
import java.io.*;// inporto tutte le classi java.io

// l'oggetto Ponte è condiviso dai thread
// delle classi autoN e autoS

class Ponte{
	
 private int cont;
 private boolean autoN;
 private boolean autoS;
 private int num_auto;
 
 // Costruttore della classe Ponte
 public Ponte(int n){
 	
 	this.num_auto = n;
 	cont = 0;
 	autoN = false;
 	autoS = false;
 }
 
 //metodo sincronizzato sull'oggetto Ponte
 public synchronized void entraN(){				// entra in wait nel caso che nel ponte siano presenti
 	while(autoS == true || cont >= num_auto){	//macchine provenienti da sud oppure se la capienza
 		try{									//max sia stata superata
 			wait();
 		}
 		catch(InterruptedException ie){}
 	}
 	cont++;
 	autoN = true;
 }
 
 //metodo sincronizzato sull'oggetto Ponte
 public synchronized void entraS(){
 	while(autoN == true || cont >= num_auto){ // entra in wait nel caso che nel ponte siano presenti
 	 try{									  //macchine provenienti da nord oppure se la capienza
 	 	wait();								  //max sia stata superata
 		}
 	 catch(InterruptedException ie){}
 	}
 	cont++;
 	autoS = true;
 	
 }
 
 //metodo sincronizzato sull'oggetto Ponte
 public synchronized void esceN(){
 	cont--;
 	notify(); // risveglio comunque un thread per ogni macchina che esce. Il thread poi 
 			 // provvederà a verificare se ci sono le condizioni per entrare sul ponte
 		if(cont == 0){
 		autoN = false;
 		System.out.println("Adesso sul ponte non sono presenti macchine");
 		notifyAll(); // nel caso del ponte vuoto risveglio tutti i thread
 	}
 }
 
 //metodo sincronizzato sull'oggetto Ponte
 public synchronized void esceS(){
 	cont--;
 	notify(); // risveglio comunque un thread per ogni macchina che esce. Il thread poi 
 			 // provvederà a verificare se ci sono le condizioni per entrare sul ponte
 	if(cont == 0){
 		autoS = false;
 		System.out.println("Adesso sul ponte non sono presenti macchine");
 		notifyAll(); // nel caso del ponte vuoto risveglio tutti i thread
 	}
 }
}

class autoN extends Thread{
	
	private Ponte ponte;
	private int id;
	private int count;
	
	//costruttore della classe autoN
	public autoN(Ponte ponte, int id){
		
		count=0;
		this.ponte=ponte;
		this.id=id;
	}
	
	public void run(){
	while(count<7){
	 ponte.entraN();
	 entra();
	 ponte.esceN();
	 count++;
	 ferma();
	}			
	}
	
	public void entra(){	
	System.out.println("L'auto "+id+" da nord entra.");
	try{
		Thread.sleep(1000-10*id);	//tempo arbitrario di attesa della singola macchina 	
	}								// all'interno del ponte
	catch(InterruptedException ie){}	
}

public void ferma(){
		try{
		Thread.sleep(1000-10*id);	// attesa arbitraria all'uscita del ponte	
	}
	catch(InterruptedException ie){}		
	}		
 	
}

class autoS extends Thread{
	
	private Ponte ponte;
	private int id;
	private int count;
	
	public autoS(Ponte ponte, int id){
		
		count=0;
		this.ponte=ponte;
		this.id=id;
	}
	
	public void run(){
	// numero arbitrario di volte che una certa macchina può attraversare il ponte 	
	//try {
		while(count<7){
		
	 ponte.entraS();
	 entra();
	 ponte.esceS();
	 count++;
	 ferma();
	 if (  count==7)
	 {System.out.println(" Il ponte è crollato e non possono passare più macchine");
		}
//	}
	//	catch( Exception e)
		//	{}
		//	finally {
		//		     System.out.println(" Il ponte è crollato e non possono passare più macchine");
		//	}
	}
	}	
	public void entra(){	
	System.out.println("L'auto "+id+" da sud entra.");
	try{
		Thread.sleep(1000-10*id); //tempo arbitrario di attesa della singola macchina 	
	}								// all'interno del ponte		
	
	    catch(InterruptedException ie){}		
	}
	
	public void ferma(){
		try{
		Thread.sleep(1000-10*id); // attesa arbitraria all'uscita del ponte
	}
	catch(InterruptedException ie){}		
	}		
} 

public class Automobile{
	
private static BufferedReader input = new BufferedReader(new InputStreamReader( System.in ) );

	public static void main(String[] args){
	
	int n=0;	
	int k=0;
	int h=0;
		
	System.out.print("Inserisci di seguito il numero di macchine che possono stare contemporaneamente sul ponte: ");
	 try{
	 n = Integer.parseInt(input.readLine()); // acquisizione da linea di comando
	 }
	 catch(IOException ioe){}
	 
	 System.out.print("Inserisci il numero di macchine che partono da nord e vanno in direzione sud: ");
	 try{
	 	k = Integer.parseInt(input.readLine());
	 }
	 catch(IOException ioe){}
	 
	 System.out.print("Inserisci il numero di macchine che partono da sud e vanno in direzione nord: ");
		try{
		 h = Integer.parseInt(input.readLine());
	 }
	 catch(IOException ioe){}


				Ponte ponte = new Ponte(n);
		
		for(int i=0; i<=k; i++){
		autoN nord = new autoN(ponte,i);	
	    nord.start();
		}
		
		for(int i=0; i<h; i++) {
	    autoS sud = new autoS(ponte,i);	
	    sud.start();
		}
		}
}
__________________
Ho concluso felicemente molte trattative su questo forum!
Solido è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Heatspreader originale al posto del wate...
Ubisoft ha definitivamente archiviato Wa...
Motivair by Schneider Electric presenta ...
Un dissipatore che non richiede energia ...
Con Maia 200 Microsoft alza l'asticella ...
La Cina impone requisiti anche per lo st...
Apple lancia AirTag aggiornato: range es...
Microsoft risolve i blocchi di Outlook: ...
OpenAI verso il disastro finanziario? L’...
X nei guai: l'UE indaga sui pericoli del...
Caso Corona-Signorini: il giudice blocca...
470 petaFLOPS con una frequenza di 56 GH...
WhatsApp: abbonamento per rimuovere la p...
Xiaomi Redmi Note 15 in promozione: smar...
NVIDIA investe 2 miliardi in CoreWeave: ...
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: 19:54.


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