Saber si se ha creado un objeto
Hola.
Tengo un TclientDataSet que se crea en tiempo de ejecución, es de ambito global. Y me gustaría saber si se ha creado previamente. He probado esto pero no va:
|
Hola Cecilio, para ello tienes el Assigned.
Saluditos |
Caro. Gracias por la prontitud.
:) |
Assigned es esencialmente lo mismo que la comparación con nil por lo que si falla uno también el otro. Es raro que falle porque siendo una variable global, tendría que inicializarse a nil. Sin embargo, veo que en el código que nos presenta Cecilio usa
lo cual es incorrecto para crear el objeto y quizá de ahí venga la falla. Tendría que ser así:
// Saludos |
También sería bueno, que si en el código lo liberas para volver a crearlo, te asegures de que al liberar coge valor nil.
|
Cita:
No me había fijado bien como estaba creando su ClientDataSet, ayer respondi rapido y me desconecte despues. Como te dice el amiguito Roman no debería fallar ya que con el Assigned es como si estuvieras preguntando.
La creación de tu ClienDataSet tampoco esta correcta, debes hacerlo como te indica Roman y podrías hacer algo así.
Tengo una pregunta yo pense que si no creabas el objeto apuntaba a nil no importando que sea una variable global o una local, acabo de hacer la prueba, si es una variable local no apunta a nil, siendo así con el codigo anterior entra al if libera y al intentar crear te sale un AccessViolation. Estaba haciendo un procedimiento donde mi Objeto es una variable Local y ya me rompiendo mi cabeza porque no estaba funcionando bien, ahora veo que no estaba apuntando a nil, en mi programa en una parte según una condición creaba mi objeto y mas abajo preguntaba si estaba creado entonces que haga algo. ¿Me pueden explicar porque no apunta a nil cuando es variable local, la solución para una variable local sería hacer que ese tu objeto apunte a nil antes de hacer algo?. Cecilio, libera tu ClientDataSet con FreeAndNil como te dice Neftali. Saluditos |
No sé el por qué, quizás por eficiencia, tarda menos en ejecutar procedimientos locales porque no tiene que inicializar las variables.
Muchas veces es redundante, delphi la inicializa y nosotros la usamos en un bucle for que también la inicializa.... pues ... ¿pá qué? ;). Mi comentario es sólo para añadir que pasa con todas las variables locales, incluso un Integer, currency, etc no tendrá el valor cero como puede esperarse. Saludos |
Cita:
No hay problema entonces la solución sería cuando tenga un objeto como variable local inicializarlo en nil aunque no lo haya creado, para no tener problemas en el caso que describo en mi anterior mensaje. Saluditos |
Cita:
Documento. Saludos. |
Cita:
Esto es absolutamente válido :
Saludos |
OFFTOPIC: Me alegra que te vayas "re-educando", lo digo porque sin el enlace al documento, tendríamos otra divertida polémica.
Te agradezco por mi parte, ese enlace. Primero usaba F <> nil, después de un tiempo me acostumbré a usar Assigned, y desde hace poco dije, ¿qué diferencia hay? pues nada vuelvo a lo de siempre, y como digo, desde hace poco volví a usar F <> nil, ni siquiera lo puse en duda ni busqué en internet. Desde ahora queda claro que usaré Assigned. Repito, gracias. |
Cita:
Desde ahora queda claro que usaré Assigned. Cita:
|
Cita:
De todas formas, a mi en lo particular me gusta más usar Assigned en todo caso, por una cuestión de legibilidad, pero eso ya es gusto personal. Cita:
Cita:
// Saludos |
Cita:
Saluditos |
Cita:
Cita:
Cita:
Saludos |
Cita:
Cita:
|
Donald, quizas deberias cambiar esta linea:
por esta otra.
de esta manera estas instanciando la clase dentro de un objeto, en el ejemplo anterior lo asignas como perteneciente a esa clase, pero nunca se inicializa. |
A manera de explicación a los compañeros que no les quede claro, digamos que un constructor como TObject.Create llama en automático al método de clase NewInstance. Siendo un método de clase, NewInstance (al igual que el constructor) existe independientemente de cualquier instancia de la clase, y es el encargado de asignar memoria para el nuevo objeto y devuelve un apuntador (referencia) a dicho objeto. Ese valor devuelto es el que se asigna a la referencia en una construcción como
Si simplemente hacemos
el objeto sí se crea, pero nunca lo asignamos a la variable ds y de ahí todos los riesgo de violación de acceso, pues ds, al no haber sido inicializado, apunta a un lugar "aleatorío" en la memoria (o nil en el caso de variables globales). En resumen, el objeto existe, pero ds no apunta a él. // Saludos |
Bueno Roman, gracias por escribir lo que te explique, no encontraba las palabras, te equivocastes en unas cositas pero no importa :D:p
|
Disculpa Eduardo, trataré de poner más atención la próxima vez :D
// Saludos |
La franja horaria es GMT +2. Ahora son las 20:06:05. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi