PDA

Ver la Versión Completa : La comparación siempre evalúa a falso


salvica
24-08-2004, 22:33:07
Hola, a ver si me podeis echar una mano.

var
tmpFecha : TDateTime;
tmpHora : TDateTime;
strSqlTabla : string;
Y, M, D : word;
H, N, S, MS : word;
begin
DecodeDate( Now, Y, M, D );
D := 21;
M := 8;
Y := 2004;
DecodeTime( Now, H, N, S, MS );
tmpFecha := EncodeDate( Y, M, D );
H := H - 6;
if( H<0 ) then begin //----------> Comparison alwais evaluates to False
H := 24 - H;
tmpFecha := tmpFecha - 1;
end;
tmpHora := EncodeTime( H, 0, 0, 0 );


Supongo que si a las tres de la madrugada le resto seis ¿dará negativo?
Gracias a todos

roman
24-08-2004, 22:48:46
Supongo que si a las tres de la madrugada le resto seis ¿dará negativo?


No.

Aritméticamente hablando claro que sí, pero H es de tipo Word que sólo puede ser no negativo. Cuando asignas

H := H - 6

el compilador no protesta porque no puede saber el valor original de H pero durante la ejecución, como H es no negativo te trunca el resultado a 0.

Pero justamente, como H siempre será no negativo, el compilador sabe de antemano que tal comparación jamás será cierta y de ahí la advertencia.

// Saludos

salvica
24-08-2004, 23:19:41
Gracias Román, esta noche me estas dando clases
Saludos

Mick
25-08-2004, 00:33:38
Solo comentar a titulo informativo, que realmente el resultado no se trunca a cero. El resultado de la resta da el mismo valor fisico lo que cambia es la forma interpretar ese valor por el procesador.

Por ejemplo, si tenemos una variable de tamaño de word (2 bytes) con el valor 0 (este definida con signo o sin el, esto no importa para las operaciones):

En binario el valor cero guardado por la variable seria:

00000000 00000000

Si le restamos 1, el resultado de la resta seria:

11111111 11111111

Ahora lo que cambia es que si se le ha indicado al procesador que interprete el valor como sin signo, el numero resultante pasado a decimal se considera como:

11111111 11111111 = 65535

Si se le indica al procesador que interprete esa variable como con signo, el numero correspondiente en decimal se considera que es:

11111111 11111111 = -1

Simplificando un poco podemos decir que el primer bit se interpreta como un bit de signo de modo que si esta a 1 el numero se considera negativo si esta a 0 es positivo.

Saludos
Miguel

roman
25-08-2004, 02:40:00
Sí sí, tienes toda la razón Mick. Yo juraba que lo que tu describes es lo que pasaba y estaba a punto de ponerlo así pero se me ocurrió probarlo antes y cual no fue mi sorpresa al ver que obtenía cero. Pero obviamente algo hice mal en la "prueba". :o

// Saludos