Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-11-2013, 19:03   #1
dyablo96
Senior Member
 
L'Avatar di dyablo96
 
Iscritto dal: Mar 2013
Città: vicino vicenza
Messaggi: 787
[c]processi forcati che cercano un numero

ciao a tutti, ho un problema nel seguente esercizio:
allora dopo aver generato un vettore con dei numeri casuali devo forkare un certo numero di processi che decide l'utente.
ora ogni processo forkato dovra cercare in una certa area del vettore.
così creo una matrice che in base alla lunghezza del vettore e del numero dei processi contiene l'inizio e la fine dell'area riservata ad ogni processo figlio.
gli spazzi esclusi dovranno essere controllati dal processo padre.
io incontro problemi solo nel momento in cui i processi figli devono cercare un numero, infatti sono così veloci che non faccio in tempo ad incrementare la riga della matrice di ricerca che loro hanno già acquisito l'area di ricerca sbagliata.

forse però se vi posto il codice che devono eseguire i processi figli e il processo padre capite meglio .

Codice:
        if(PIDfiglio != ProcessoPadre)
	{
		int inizio = matrice_ricerca[indice_riga_matrice][1];
		int fine = matrice_ricerca[indice_riga_matrice][2];
		indice_riga_matrice++;
		for(i=inizio;i<=fine;i++)
		{
			if(elementi[i] == num_da_cercare)
			{
				printf("F: E' stato trovato alla posizione %d del vettore elementi\n",i);
			}
		}
	}
	else
	{
		sleep(2);
		int inizio = matrice_ricerca[Numero][1];
		int fine = matrice_ricerca[Numero][2];
		for(i=inizio;i<=fine;i++)
		{
			if(elementi[i] == num_da_cercare)
			{
				printf("P: E' stato trovato alla posizione %d del vettore elementi\n",i);
			}
		}
		
	}
se non avete capito quello che devo fare scrivete pure, cercherò di essere ancora più chiaro
__________________
il mio pc [Case] Cooler Master Elite 370[RAM]Vengeance Blue1600MHz 8GB cl9[Scheda Madre AsRock B75 PRO3-M[CPU] Intel i5-3470 3,2GHz[Masterizzatore Interno] Samsung SH-224BB 24x[Alimentatore PC] Seasonic S12II-520 520W 80+ Bronze[Hard Disk Interno] 3.5" Toshiba 500GB+ WD Caviar Blue 500GB[vga] sapphire 7870[monitor] LG 22EA53VQ-P LCD IPS LED 21.5 "
dyablo96 è offline   Rispondi citando il messaggio o parte di esso
Old 11-11-2013, 19:26   #2
dyablo96
Senior Member
 
L'Avatar di dyablo96
 
Iscritto dal: Mar 2013
Città: vicino vicenza
Messaggi: 787
credo di aver capito l'errore, la varibile che indica ai processi la riga da cui leggere loro la copiano dal processo padre quindi anche se un processo l'aumenta per far leggere al processo successivo la prossima riga il processo successivo leggerà la variabile presente nel processo padre che non è stata modificata, io dovrei fare in modo che la variabile sia comune ai processi figli, come potrei fare ????
__________________
il mio pc [Case] Cooler Master Elite 370[RAM]Vengeance Blue1600MHz 8GB cl9[Scheda Madre AsRock B75 PRO3-M[CPU] Intel i5-3470 3,2GHz[Masterizzatore Interno] Samsung SH-224BB 24x[Alimentatore PC] Seasonic S12II-520 520W 80+ Bronze[Hard Disk Interno] 3.5" Toshiba 500GB+ WD Caviar Blue 500GB[vga] sapphire 7870[monitor] LG 22EA53VQ-P LCD IPS LED 21.5 "
dyablo96 è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2013, 18:06   #3
dyablo96
Senior Member
 
L'Avatar di dyablo96
 
Iscritto dal: Mar 2013
Città: vicino vicenza
Messaggi: 787
risolto, posto il codice così se qualcuno ha lo stesso problema può trovare la soluzione

Codice:
//Ciclo che genera i processi figli
	for(i=0; i<Numero; i++)
	{
		//Se il padre esegue questo controllo allora risponderà positivamente e crerà un nuovo processo figlio
		if(getpid() == ProcessoPadre)
		{
			n = fork();
		}
		//Se un processo figlio incontra il controllo precedente allora esegue l'else e quindi termina l'esecuzione del for
		else
			break;
	}
	//Ogni processo forkato ha una i differente che lo identifica
	//Sottraggo 1 alla i perche essa indica l'indice di riga della matrice che però parte da 0
	i--;

//Pid del figlio
	int PIDfiglio = getpid();
	
	//A questo if rispondera positivamente solo il figlio
	if(PIDfiglio != ProcessoPadre)
	{
		//Creo 2 varibili ricavate dalla matrice che indicano l'inzio e la fine della lettura
		int inizio = matrice_ricerca[i][1];
		int fine = matrice_ricerca[i][2];
		//Inizio a leggere
		for(i=inizio;i<=fine;i++)
		{
			//Se trovo una corrispondeza stampo un messaggio
			if(elementi[i] == num_da_cercare)
			{
				printf("F %d: E' stato trovato alla posizione %d del vettore elementi\n",PIDfiglio,i);
			}
		}
	}
	//Solo il padre entrerà nell'else
	else
	{
		//Dato che non sono riuscito a far funzionare il waitpid allora faccio aspettare al padre 1 secondo
		//Così che tutti gli altri processi figli possano terminare
		sleep(1);
		//Ciclo di lettura per il padre
		for(i=start_padre;i<=fine_padre;i++)
		{
			//Se trovo una corrispondenza allora stampo un messaggio
			if(elementi[i] == num_da_cercare)
			{
				printf("P: E' stato trovato alla posizione %d del vettore elementi\n",i);
			}
		}
		
	}
	
	//Termino il programma
	return 0;
__________________
il mio pc [Case] Cooler Master Elite 370[RAM]Vengeance Blue1600MHz 8GB cl9[Scheda Madre AsRock B75 PRO3-M[CPU] Intel i5-3470 3,2GHz[Masterizzatore Interno] Samsung SH-224BB 24x[Alimentatore PC] Seasonic S12II-520 520W 80+ Bronze[Hard Disk Interno] 3.5" Toshiba 500GB+ WD Caviar Blue 500GB[vga] sapphire 7870[monitor] LG 22EA53VQ-P LCD IPS LED 21.5 "
dyablo96 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Torna a soli 25,40€ il caricatore multip...
L'India chiede ai produttori di smartpho...
Apple cambia tutto sull'intelligenza art...
AWS Transform si evolve: agenti IA per m...
I social network hanno stancato gli ital...
Star Citizen supera i 900 milioni di dol...
Netflix ha eliminato la funzione Cast pe...
L'IA è una bolla e scoppier&agrav...
Un rapporto collega i data center di Ama...
Troppa concorrenza per Cherry (quella de...
Entro il 2035 la Cina vuole costruire de...
Tineco in super sconto: ultimo giorno di...
La Cina creerà una costellazione ...
I veicoli elettrici emettono radiazioni ...
Stai per acquistare una PS5? Attento al ...
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: 07:51.


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