FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Cuando y por que usar property
Hola
Estoy leyendo en la cara oculta de delphi 4 , el uso de propiedades (property) y la verdad este tio que escribe el libro se enrolla y se va del tema y al final no me he enterado la utilidad de esto . Alguien me puede decir algunos ejemplos en los que es conveniente utilizar estas propiedades . De lo que me he enterado es de como se forma : Property NombrePropieda : Tipo read FNombrePropiedad write SetNombrePropiedad; Y que puede ser read and write o sólo read , y write sólo casi nunca . Pero no sé exactamente , cuando usarlas y por qué . Saludos |
#2
|
|||
|
|||
Miraré de explicartelo:
La propiedades son como variables que otras classes pueden ver. Las propiedades se guardan internamente dentro de la classe por unas variables assignadas en la declaración de la propiedad: En tu ejemplo FNombrePropiedad es una variable privada (por convenio) de la classe. Tambien en tu ejemplo hay el procedure SetNombrePropiedad. Este procedure asignará el valor a la propiedad y te permitirá hacer más cosas en ese momento. Podrias tener una función GetNombrePropiedad. Esta función te permitiria obtener el valor de la propiedad( por ejemplo si fuera calculada) Sobre lo del read y el write es bastante trivial, simplemente indicas que se lee (read) con la función o con la variable y se escribe (write) con el procedure o la variable Espero que te ayude
__________________
Grandes frases de nuestro tiempo: "La pasta no és para tirarla, es para el Tunning" "TodoOK=False...." Enjoy it!!! |
#3
|
||||
|
||||
Las propiedades son útiles en el futuro
A que me refiero con esto... imagínate que tienes dos clases:
Como puedes ver las dos clases hacen lo mismo:
y podría parecer que es más cómodo al principio usar la clase TVariable en vez de de la clase TPropiedad pues "hay que escribir menos". Sin embargo dejamos de lado el presente y avanzamos al futuro... ahora nos damos cuenta que queremos mostrar un mensaje de error si el valor del campo miVariable es una cadena vacía. Desde la primera aproximación tenemos dos formas, bien verificamos fuera de la clase el valor introducido o bien añadimos un método que valide el texto introducido y en ambos casos recorremos nuestro código en busca de todas las veces que modificamos el valor de miVariable para añadir los cambios. Sin embargo, si hemos usado propiedades el resultado podría quedar algo así:
donde setTexto sería la función que nos valida el texto introducido. Espero que este ejemplo te ayude a explorar más detenidamente el tema de las propiedades. |
#4
|
||||
|
||||
sigo con la idea de Hector.
Las propiedades son útiles también para introducir "efectos secundarios". Supongamos que estas programando una clase:
Mas adelante... mientras vas programando el sistema, te das cuenta que queres que el mensaje de la etiqueta se actualice automáticamente en la pantalla cuando el programador lo asigne, de manera que el usuario tenga un retorno de información adecuado. Entonces, en lugar de escribir el valor de la propiedad directamente en FMensaje, creas un método SetMensaje (o cualquier otro nombre, aunque esta es la convención) y lo implementas algo como:
Luego, te das cuenta que sería de utilidad al programador poder actuar cuando hay un cambio en el valor de la propiedad mensaje de la etiqueta. Entonces añadis un evento a la clase y lo lanzas cuando cambia el valor:
En fin... usar propiedades te ayuda a mantener una interfaz consistente al programador a medida que tus clases evolucionan, validar automáticamente los valores que la clase acepta en las propiedades (por ejemplo, solo números pares o impares, etc), introducir efectos secundarios "controlados", lanzar eventos. Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#5
|
|||
|
|||
En el ejemplo de Jachguate no llego a comprender , que tiene que ver la clase TEtiquetaV
Por otro lado , según me dijeron tenia que programar una propiedad en mi programa y lo he hecho de esta manera y me funciona , aunque no sé si es la forma más correcta . Tengo un Datamodule y un FrmReformas . En el Datamodule ,tengo la tabla de reformas , TReformas con su datasource , y en el formulario tengo una tabla de componentes que corresponde a cada reforma . De tal manera que si en el formulario de Reformas , vas recorriendo la tabla de Reformas , tienen que ir apareciendo los componentes de dicha reforma . Para ello , la tabla TComponentes , hago un filter para igualar el campo de reforma con el código de la tabla reforma . Asi en el Datamodule tengo esto :
Bien esto es lo que he puesto en el DataModule , ahora en el formulario FReformas , donde esta la tabla componentes , he puesto lo siguiente
|
#6
|
||||
|
||||
Está bien como práctica de clase, aunque no le hallo sentido a lanzar un evento de esta manera, pues bastaría poner un DataSource asociado al dataset en el módulo de datos en el formulario y atender el evento OnDataChange de este.
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#7
|
|||
|
|||
Hola,
Hay que aclarar una cosa, las clases, objetos, interficie, no se utilizan por que si. Nadie se pondrá a hacer una clase para guardar un solo valor. Tened en cuenta que las clases nacen de modelar los objetos de un problema y tienen su semantica dentro del problema que quieres resolver. Resumiendo, la teoria de programación orientada a objetos tiene unas especificaciones que a priori no sirven para nada, pero que en diseños complejos pueden salvarte de tener que hacer miles de "xapuzas" para ajustarte al diseño. No es que sea un purista de las OOP, pero va muy bien conocer todas estas opciones.
__________________
Grandes frases de nuestro tiempo: "La pasta no és para tirarla, es para el Tunning" "TodoOK=False...." Enjoy it!!! |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
pregunta tonta sobre "property" | patroclus02 | OOP | 6 | 09-10-2006 18:14:31 |
Interbase/Firebird. Clasic ó Superserver. ¿Cuando usar cada una? | Delphius | Firebird e Interbase | 9 | 08-08-2006 23:37:30 |
Ayuda para sobreescribir property | Egroc | OOP | 3 | 12-11-2005 22:24:09 |
Excepción "Invalid property value" en botón inexistente | melanthea | C++ Builder | 1 | 07-07-2004 18:12:39 |
a proposito de property | pickman | Varios | 2 | 18-07-2003 04:10:34 |
|