[QT C++] Como salir del bucle??

Iniciado por x7uk, 28 Noviembre 2012, 16:56 PM

0 Miembros y 1 Visitante están viendo este tema.

x7uk

Hola! Bueno programe un soft en C++ con Qt que envia y recibe datos por el puerto serie de la PC. Funciona perfecto pero ahora intentaba programar que busque automaticamente cual de los 16 puertos (COM) esta abierto y ahi el problema!

Pondre esa parte del codigo primero:

QList<QString> puertos;
        puertos << "COM2" << "COM3" << "COM4" << "COM5" << "COM6" << "COM7" << "COM8" << "COM9"<< "COM10" << "COM11" << "COM12" <<"COM13" << "COM14" << "COM15 "<< "COM16";
        QString COM;
        while(!conexion){ //conexion es una varible qe declare arriba. Mientras NO haya conexion:
             foreach(COM, puertos){
                port->setPortName(COM); //Seteo el nombre del puerto ej: COM7
                if(port->open(QextSerialPort::ReadWrite)){// si conecta:
                     conexion = true;
                     emit Connection_Ready(conexion, COM);
                }
              }//sino seguira sin conexion e intentara de nuevo con el siguiente COM del array.
           if (!conexion){
              emit Connection_Fail("[X]TODOS LOS PUERTOS CERRADOS!");
           }//la idea es que si los 16 COM estan cerrados imprima esto.
        }


Ahora bien, si por ejemplo tengo el COM7 abierto, el programa arranca prueba hasta ese COM y como esta abierto  ahi queda y funciona perfecto. El problema es cuando TODOS LOS COM ESTAN CERRADOS. Ya que al parecer entra en uN bucle infinito y el programa se cuelga  :( Como puedo hacer para que esto deje de pasar? y en lugar de colgarse ejecute el ultimo bloque y mande al form que "TODOS LOS PUERTOS ESTAN CERRADOS" como quiero? :/

Gracias de antemano! se que tengo varios errores ahi ojala me puedan ayudar!
backtrack/hispanic-community-member/x7uk

febef

#1
Hola!

   Creo que el problema esta acá el bucle while esta de más.


Código (cpp) [Seleccionar]
       foreach(COM, puertos){
               port->setPortName(COM); //Seteo el nombre del puerto ej: COM7
               if(port->open(QextSerialPort::ReadWrite)){// si conecta:
                    conexion = true;
                    emit Connection_Ready(conexion, COM);
               }


   Al poner este bucle estamos recorriendo todos los elementos de COM, por lo tanto se va a conectar a todos los que pueda.

   Lo que tendrías que hacer es cuando ya este conectado a uno salir del foreach.

   Por otro lado el foreach solo pasa una vez por cada elemento por lo que no va a seguir probando siempre. Con el while lo que hacías es después de probar una vez con cada uno lo volvía a hacer si no tenia conexión.

   Si hay algo que haga q el while tenga que estar si o si entonces cambialo por una for que repita el procedimiento x veces ejemplo:
Código (cpp) [Seleccionar]
for(int i=0; !conexion && i<veces;i++ )
{
 //codigo
}


edit:
Es más si cambias el foreach por un for podes hacer que termine cuando haya conectado...



x7uk

Tenias razon! saque el while y problema solucionado! ya funciona bien :) Mil gracias Fex!
backtrack/hispanic-community-member/x7uk