Foros del Web » Programación para mayores de 30 ;) » C/C++ »

error con hilos en este programa

Estas en el tema de error con hilos en este programa en el foro de C/C++ en Foros del Web. que tal a todos tengo el siguiente programa que logicamente me debe de correr con 4 hilos pero lo unico que hace es subir el ...
  #1 (permalink)  
Antiguo 20/09/2009, 14:17
 
Fecha de Ingreso: marzo-2009
Mensajes: 163
Antigüedad: 15 años, 9 meses
Puntos: 0
error con hilos en este programa

que tal a todos tengo el siguiente programa que logicamente me debe de correr con 4 hilos pero lo unico que hace es subir el tiempo por lo cual esta mal haber si alguien puede ayudarme este es el codigo.

Código:
#include  <stdio.h>
#include  <unistd.h>
#include  <stdlib.h>
#include  <pthread.h> // Definen funciones para manejo de hilos
#include  <sys/time.h>
#define ciclos_x_seg 250000000
void *thread_function(void *arg);  // Función donde inicia el hilo
int main()
{
     	// Definición de variables
	int res;
     	pthread_t a_thread,b_thread;    // Identificador del hilo
     	void *thread_result;
     	long long start_ts;
	long long stop_ts;
    	long long elapsed_time;
   	long lElapsedTime;
    	struct timeval ts;
    // Toma tiempo inicial
    	gettimeofday(&ts, NULL);
    	start_ts = ts.tv_sec * 1000000 + ts.tv_usec; // Tiempo inicial
    /* Aquí se crean los hilos */
    	res = pthread_create(&a_thread, NULL, thread_function,NULL);
    	if (res != 0) 
	{
	        perror("Thread creation failed");
	        exit(EXIT_FAILURE);
	}
    	res = pthread_create(&b_thread, NULL, thread_function,NULL);
    	if (res != 0) 
	{
	        perror("Thread creation failed");
	        exit(EXIT_FAILURE);
    	}
   
    	res = pthread_join(a_thread, &thread_result);
 // Esperar a que terminen los hilos
    	if (res != 0)
    	{
        	perror("La unión del hilo ha fallado");
        	exit(EXIT_FAILURE);
    	}
    	res = pthread_join(b_thread, &thread_result);
    	if (res != 0)
    	{
        	perror("La unión del hilo ha fallado");
        	exit(EXIT_FAILURE);
    	}
    // Se toma el tiempo final
    	gettimeofday(&ts, NULL);
    	stop_ts = ts.tv_sec * 1000000 + ts.tv_usec; // Tiempo final
    	elapsed_time = stop_ts - start_ts;
    	printf("Tiempo = %4.2f segundos\n",(float)elapsed_time/1000000);
    	exit(EXIT_SUCCESS);
}
// Función donde inicia la ejecución el hilo secundario
void *thread_function(void *arg)
{
    int i;
    for (i=0; i< 2*ciclos_x_seg ; i++);   // Ejecutar instrucciones del CPU
                                   // Uso intensivo del CPU
    	pthread_exit(NULL);
}
  #2 (permalink)  
Antiguo 20/09/2009, 19:40
Avatar de kike00  
Fecha de Ingreso: febrero-2005
Ubicación: El Salvador
Mensajes: 180
Antigüedad: 19 años, 10 meses
Puntos: 7
Respuesta: error con hilos en este programa

lo que veo es que solo creas 2 hilos,
otra cosa, te puedes ahorrar un par de lineas si haces esto:
Código C:
Ver original
  1. if (pthread_create(&a_thread, NULL, thread_function,NULL)) {
  2.             printf("Thread creation failed");
  3.             return -1;
  4.     }
  5.     if (pthread_create(&b_thread, NULL, thread_function,NULL)) {
  6.             printf("Thread creation failed");
  7.             return -1;
  8.     }

y en vez de
Código C:
Ver original
  1. res = pthread_join(a_thread, &thread_result);
  2.          // Esperar a que terminen los hilos
  3.         if (res != 0)
  4.         {
  5.             perror("La unión del hilo ha fallado");
  6.             exit(EXIT_FAILURE);
  7.         }
  8.         res = pthread_join(b_thread, &thread_result);
  9.         if (res != 0)
  10.         {
  11.             perror("La unión del hilo ha fallado");
  12.             exit(EXIT_FAILURE);
  13.         }

pon

Código C:
Ver original
  1. pthread_join(a_thread,NULL);
  2. pthread_join(b_thread,NULL);

Y pues si le agregas mas hilos es natural que aumente el tiempo, ya que los hilos no se ejecutan exactamente paralelamente.

Última edición por kike00; 20/09/2009 a las 19:51
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 18:25.