![]() |
Return value of function might be undefined
Buen dia
Tengo un problema con una funcion en la cual el compilador me marca warning, debido a que el codigo no es suficiente para asignar el resultado de la funcion es decir, no he identificado todos los comportamientos posibles de mi funcion. Le he dado vueltas y no puedo identificar que me falta. Todavia me encuentro atrapada en la programacion procedural.
Gracias |
For
el problema esta en que nada te asegura que se ejecute por lo menos alguna vez el ciclo for
For b:= 0 to (ListFirst.Items.Count-1) do con lo cual terminas la funcion sin asignar un valor |
Hola,
Si ListFirst.Items.Count es menor que 0 nunca se asignaria un resultado de retorno, y esto es lo que te marca el compilador, no importa demasiado el warning debido a que Items.Count en la practica nunca es menor que cero, pero esta propiedad esta definida en el objeto TStrings como integer , lo que significa que teoricamente podria tener un valor negativo. Saludos |
:) Gracias por la ayuda
He resuelto el problema. El que se ejecute o no el codigo depende del estado de la caja de verificacion. Saludos y buen resto de dia |
Normalmente al inicio de ese tipo de funciones, se suele poner Result:= false; de esta forma eliminas la advertencia del compilador, y le das un valor según convenga.
Result := false equivale a BorrarLista:= False Me gusta más usar "Result", porque usando el nombre de la función, puede parecer que es una variable; al leer el código suele desconcertarme. Saludos |
Efectivamente el Result debe inicializarse con un valor
Efectivamente mi problema tambien radicaba que no inicializaba Result
Gracias por el comentario Lepe :) |
La franja horaria es GMT +2. Ahora son las 12:53:20. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi