Hilos en Visual C++ utilizando la clase CWinThread

Por:ivancp,enviado 14 Mar 2004
Este es un programa que demuestra como utilizar la clase CWinThread en forma sencilla. El ejemplo utiliza tres hilos y comprueba la rapidez de tres métodos de ordenamiento conocidos: QuickSort, SelectSort y el metodo de Burbuja, y se puede ver que uno de ellos es mucho mas eficiente, y el gran perdedor de esta prueba es el método de la Burbuja.

thread_demo1.gif
Aplicación de ordenamiento simultaneo ejecutándose


Primero se crera una clase base para el manejo de los hilos, en la que se implementarán funciones comunes en todas las demás clases derivadas. En cada clase derivada se implementa una funcion que efectua el ordenamiento de ciertos datos.

thread_demo2.gif
Diagrama de clases que muestra como debe heredarse de la clase CWinThread


El codigo que les voy a mostrar es parte de la clase CQuickSort con la funcion que ejecuta la operacion de ordenado y la otra la funcion que contiene el algoritmo de ordenamiento QuickSort. Todo esta en el proyecto en Visual C++ que adjunto al artículo.

Code: Seleccionar todo
  1. int CQuickSort::Run()

  2. {

  3.   m_iIterac = 0;

  4.   quickSort(0,MAX_VALORES);

  5.   return 0;

  6. }

  7.  

  8. void CQuickSort::quickSort(int left, int right)

  9. {

  10.   int leftIndex = left;

  11.   int rightIndex = right;

  12.   int partionElement;

  13.  

  14.   if ( right > left)

  15.   {

  16.  

  17.   partionElement = m_piValores[ ( left + right ) / 2 ];

  18.  

  19.     while( leftIndex <= rightIndex )

  20.     {

  21.  

  22.       while( ( leftIndex < right ) &&

  23.         ( m_piValores[leftIndex] < partionElement ) )

  24.         ++leftIndex;

  25.  

  26.       while( ( rightIndex > left ) &&

  27.         ( m_piValores[rightIndex] > partionElement ) )

  28.         --rightIndex;

  29.  

  30.       if( leftIndex <= rightIndex )

  31.       {

  32.         Intercambiar(leftIndex, rightIndex);

  33.         ++leftIndex;

  34.         --rightIndex;

  35.       }

  36.     }

  37.  

  38.     if( left < rightIndex )

  39.       quickSort( left, rightIndex );

  40.    

  41.     if( leftIndex < right )

  42.       quickSort( leftIndex, right );

  43.   }

  44. }

Archivos Adjuntos

  • thread_demo.zip30.43 KiB
    Código fuente del proyecto de hilos con el ordenamiento simultaneo.

Otros Artículos en esta sección

  • Uso de CListCtrl y DAO
    na forma de utilizar el control ActiveX MSFlexGrid en aplicaciones Visual C++ basadas en MFC, este control es útil para visualizar datos.
    Por: MicroLogic©Software,2005-04-20
  • HACHA (AXE) Cortador de Archivos
    Es una versión del cortador de archivos Hacha que incluye el código fuente, puedes utilizar el cortador para enviar archivos en medios pequeños.
    Por: Lizardo,2004-03-14
  • Cadenas de Conexion ADO
    Una lista de Cadenas de Conexión que se pueden utilizar en conexiónes Bases de Datos desde Visual C++ utilizando ADO. También sirven para otros lenguajes de programación.
    Por: carlos.antollini,2008-02-02
¿Alguna duda? Sientete libre de hacer tus pruntas en nuestro:
foro deVisual C++ »