400 likes | 562 Views
Definición y cumplimiento de responsabilidades. Giovanni Hernández P. Nivel 4. Contrato entre dos sujetos : el que lo implementa y el que lo usa . Necesito que me adicione este libro al catálogo. No he verificado si ya existe ahí. El libro esta en buen estado.
E N D
Definición y cumplimiento de responsabilidades Giovanni Hernández P. Nivel 4
Contrato entre dos sujetos: el que lo implementa y el que lo usa. Necesito que me adicione este libro al catálogo. No he verificado si ya existe ahí. El libro esta en buen estado Ok. Yo lo adiciono si no esta en el catálogo. Si ya está le informo para que Usted decida que hacer
Contrato de un método Acuerdo entre quien implementa el método y quien lo usa Método Se establece claramente Signatura del método Contrato de un método Condiciones para definir los resultados
Caso de estudio No 1 Club social
Caso de estudio No 1 • Comprensión de los requerimientos. • Comprensión del mundo del problema. • Definición de la arquitectura.
Comprensión del mundo del problema Un club tienemuchossocios Solo se necesita el nombre de la persona por lo cuál se representa con String Un socio tienemuchasfacturas Un socio puedetenermuchas personas autorizadas
Definición de la arquitectura ClubTest SocioTest Club Socio Factura
Declaración de lasclases public class Club { } public class Socio { } public class Factura { }
Asignación de responsabilidades Técnica del experto • Técnicas de asignaciónde responsabilidades El dueño de la informaciónes el responsable • Técnica de descomposición de requerimientos Permitequeotrostenganaccedan y puedanpedircambios en la información Tiene en cuentalasreglas del mundo
Asignación de resposabilidades Caso de estudio • Quíenes el responsable de agregar un nuevo socio al club? • Quíenes responsible de registrar una persona autorizadapor un socio?
Asignación de responsabilidades Técnica de descomposición de los requerimientos • Técnicas de asignaciónde responsabilidades Descomponer en sub-problemas Identificar los pasos de invocación de métodos • Técnica del experto Asignarresposabilidades a lasclases
Asignación de responsabilidades Descomposición del requerimiento • Buscarsi el socio quequierepagar la facturaexiste (buscar Socio) • Si el socio existe, obtenertodaslasfacturaspendientes (darFacturas) • Pagar la facturaseleccionada (pagarFactura)
Asignación de responsabilidades Descomposición del requerimiento • Buscarsiexiste el socio a quien se le vaagregaruna persona autorizada (buscarSocio) • Dado el nombre de una persona, verificarsiesa persona yapertenece al grupo de autorizados del socio (existeAutorizado) • Asociar con el socio unanueva persona autorizada (agregarAutorizado)
Asignación de responsabilidades R2-Registrar una persona autorizada Paso No 1. Localizar el socio buscarSocio() Paso No 2. Verificarque la persona que se va a agregar no estayaincluida existeAutorizado() agregarAutorizado() Paso No 3. Agregar al socio el nombre de la persona autorizada
Manejo de excepciones • Programación Idacador de queexiste un error en el programa • Codificación en programación Excepción en programación Se produce cuando un método no terminacorrectamente Se produce porunaaccióninesperada en un método
Manejo de excepciones public void afiliarSocio(String cedula,Stringnombre) throws Exception { ….. } Con esta declaración el método advierte a todos los que lo utilizan que puede producirse una excepción al utilizarlo. Los métodos que hacen la invocación pueden capturar la excepción o dejarla.
Manejo de excepciones Instruccióntry-catch try { inst1; } catch (Exception e) { instr2; } Si todo funciona bien no se ejecuta ninguna de las instrucciones catch. Así se dice que cualquier excepción que se atrape se la asigna al objeto e de tipo Exception. Se puede utilizar la variable e para pedir información sobre el error.
Manejo de excepciones • La construcción de un objeto Exception y la instrucción throw public void afiliarSocio(String cd, String nm) throws Exception { // Revisaque no exista un socio con la mismacédula Socio s = buscarSocio( cd ); if ( s == null) { //Se crea el objeto socio Socio nuevoSocio = new Socio( cd, nm ); // Se agrega el socio al club socios.add( nuevoSocio); } else { // Si el socio yaexistialanza la excepción throw new Exception( “El socio yaexiste” ); } }
Manejo de excepciones Flujo de control en el manejo de excepciones publicvoid m1() { try { o1.m2(); } catch( …) { } } publicvoid m2() throwsException { o2.m3(); } publicvoid m3() throwsException { o3.m4(); } Atrapa la excepción y se recupera Dejarpasar la excepción publicvoid m4() throwsException { … } Lanza la excepción
Contrato de un método Acuerdo entre quien implementa el método y quien lo usa Método Se establece claramente Signatura del método Contrato de un método Condiciones para definir los resultados
Contrato de un método publicvoidafiliarSocio( String cedula, String nombre ) throwsException Antes de ejecutar el método: • La lista de socios ya fue creada • La cédula no es null , ni vacía • No se ha verificado si ya existe un socio con esa cédula. • El nombre no es nullni vacío. Después de ejecutar el método, el resultado debe ser: • Todo funciona bien y el socio se afilia al club. • Se produjo un error y se informó del problema con una excepción.
Contrato de un método Precondiciones y postcondiciones Precondición: Aquelloque se exigeparapoder resolver un problemaplanteado a un método (Condicionesque se imponen al hacer el método). Puedenreferirse a: • El estado de un objetoqueva a ejecutar el método. • El estado de algúnelemento del mundo con el cual el objetotieneasociación. • Condicionessobre los parámetros de entradaentregados al método.
Taller No 2 Identificarprecondición de un método
Contrato de un método Precondiciones y postcondiciones Postcondición: Descripción del resultadoobtenidodespués de ejecutar un método (Compromisoqueasume al hacer el método). Puedenreferirse a: • Unadescripción del valor de retorno. • Unadescripcion del estado del objetodespués de haberejecutado el método.
Taller No 3 Identificarprecondición de un método
Preguntas • ¿Un método debe verificar en algún punto las condiciones que hacen parte de la precondición? – No. • ¿Qué lugar ocupan las excepciones en los contratos? – Únicamente lanza la excepción. • ¿Qué incluir en la precondición? – Condiciones fáciles de garantizar • ¿Por qué es inconveniente verificar todo dentro de un método invocado? – Por eficiencia.
Documentación de los contratos con Javadoc • Hace parte de la documentación del método • Generarautomáticamente la documentación con Javadoc • El contrato se expresacomo un comentario en javadoc /** … */, inmediatamente antes del método.
Documentación de los contratos con Javadoc • El contratoempieza con unadescripción general del método /** * Este métodoafilia un nuevo socio al club
Documentación de los contratos con Javadoc • Precondicionesrelacionadoscon el estado del objetoqueejecuta el método. Allí se incluyeúnicamentelasrestricciones y lasrelacionesquedebencumplir los atributos y los objetos con los cualestieneunaasociación. * <b>pre:</b>La lista de sociosestainicializada (no es null). </br>
Documentación de los contratos con Javadoc • Postcondicionesquehacenreferencia al estado del objetodespués de la ejecución del método. Allí se debendescribir la modificación de los atributos y objetosasociadosquepuedenesperarsedespués de suejecución. * <b>post:</b>Se ha afiliado un nuevo socio al club con los datos dados. </br>
Documentación de los contratos con Javadoc • Parámetros se describe los parámetros de entrada y lasprecondicionesasociadas con ellos. Para cadaparámetro se debeutilizar la etiqueta @paramseguido de nombre del parámetro, unadescripción y lassuposicionesque el métodohacesobre el. * @paramcedula Es la cédula del nuevo socio. Cedula != null, cedula != “” * @paramnombre Es el nombre del nuevo socio. nombre != null, cedula != “”
Documentación de los contratos con Javadoc • Retorno se describe el valor de retornoque se devolverácomosifuerauna variable. Para el retorno se utiliza la etiqueta @return. Para el ejemplo, no tieneretorno * @return
Documentación de los contratos con Javadoc • Excepciones se describe lasexcepcionesque el métododispara. Se utiliza la etiqueta @throws seguida del tipo de excepción y unadescripción de la situación en la quepuede ser disparada. * @throws Exception si un socio con la mismacédulayaestabaafiliado al club, disparaunaexcepciónindicandoque la nuevaafiliación no se puedellevar a cabo.
Documentación de los contratos con Javadoc /** * Este métodoafilia un nuevo socio al club * <b>pre:</b>La lista de sociosestainicializada (no es null). </br> * <b>post:</b>Se ha afiliado un nuevo socio al club con los datos dados. </br> * @paramcedula Es la cédula del nuevo socio. Cedula != null, cedula != “” * @paramnombre Es el nombre del nuevo socio. nombre != null, cedula != “” * @throws Exception si un socio con la mismacédulayaestabaafiliado al club, disparaunaexcepciónindicandoque la nuevaafiliación no se puedellevar a cabo. */ public void afiliarSocio( String cedula, String nombre) throws Exception { }
Taller No 4 Identificarprecondición de un método