<div dir="ltr">Hola Raúl,<div class="gmail_extra"><br><div class="gmail_quote">2013/1/23 raul castelar <span dir="ltr"><<a href="mailto:raulcastelar@hotmail.com" target="_blank">raulcastelar@hotmail.com</a>></span><br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">


<div><div dir="ltr">
Hola a todos.Que tal?<br><div>Aquí expongo mi primer mensaje como nuevo usuario.</div></div></div></blockquote><div><br></div><div style>Ante todo, bienvenido a la lista de correo-e.</div><div style><br></div><div style>
[CORTE]</div><div style> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div dir="ltr"><div>
</div><div><div>void LeeSerie()   //el problema está aquí en leerserie</div></div></div></div></blockquote><div><br></div><div style>Veamos el código fuente.</div><div style><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div dir="ltr"><div><div>{   COMSTAT cs; </div><div>    DWORD x,err;</div><div>    DWORD *y;</div><div>   y=&x;</div><div>   </div><div>     if( ! ClearCommError (canal, y,cs));</div></div></div></div></blockquote>
<div><br></div><div style>Aquí tienes dos errores.</div><div style><br></div><div style>El primero es que pasas 'cs' como el tercer parámetro, cuando el prototipo indica que requiere un puntero a 'COMSTAT'. Debería ser:<br>
<br>ClearCommError( canal, &x, &cs )<br></div><div style><br></div><div style>La verdad es que no es necesario definir 'y', en este caso.</div><div style><br></div><div style><br></div><div style>El segundo error es que colocas el punto y coma después de la condición, terminando esta sentencia. Sin embargo, lógicamente, te interesa que la condición controle las sentencias. Esto implica que necesitas un bloque de sentencias, indicado por llaves:</div>
<div style><br>if( !ClearCommError(canal, &x, &cs) )<br>{<br>  ...</div><div style>}</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div dir="ltr"><div><div>            err = GetLastError();</div><div>            if (err=ERROR_NOACCESS)</div></div></div></div></blockquote><div><br></div><div style>Esto es un error lógico, ya que estás asignando un valor a 'err' en lugar de comparar ambos valores. Recuerda que, en C/C++, el operador = es de asignación, y el == es de comparación de igualdad.</div>
<div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div><div dir="ltr"><div><div> printf ("\n998 (0x3E6)Acceso no válido a ubicación de memoria\n"); </div>
<div>    </div><div>   if(!ReadFile (canal, dato_r, cs.cbInQue, &x, NULL));</div></div></div></div></blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div><div dir="ltr"><div><div>            err = GetLastError();</div><div>            if (err=ERROR_NOACCESS)</div></div></div></div></blockquote><div><br></div><div style>Aquí repites los dos últimos errores anteriores:<br>
</div><div style><br></div><div style>1. Agregas el punto y coma, cuando deberías usar llaves, y</div><div style>2. Usas el operador =, cuando realmente necesitas que sea ==</div><div style><br></div><div style><br></div>
<div style>Espero que esto te ayude.</div><div style><br></div><div style>Steven</div><div style><br></div></div></div></div>