Está en la página 1de 80

UTP -1-

FACULTAD DE INGENIERIA INDUSTRIAL Y

DE SISTEMAS

Separata

Lenguaje de Programación I

Parte I

Prof. Ing. Alberto Moreno

2008-1

Ing. Alberto Moreno


UTP -2-

INDICE

1.- Introducción

2.- Tipos de Datos Variables

3.- Instrucciones de Control

4.-Diagrama de actividades

5.- Funciones de Cadena

6.- Vectores y Matrices

7.- Métodos de Usuarios

8.- Clases . Objetos, Constructores

9.- Herencias

10.- poliformismos

Ing. Alberto Moreno


UTP -3-

1.- LENGUAJE DE PROGRAMACIÓN I(JAVA)

Un lenguaje de Programación Orientada a Objetos nos permite organizar el código en


entidades como las clases compuestas de datos y funciones, y a través de la
característica de la herencia podemos organizar las clases en jerarquías.

El objetivo es el de enseñar al lector a traducir la descripción de un problema o situación


que se plantea a código, a organizar el código en funciones, a agrupar datos y funciones
en clases y las clases en jerarquías.

MARCO TEORICO

El lenguaje de programación Java

Java es un lenguaje de programación de alto nivel que tiene las siguientes


características:

• Orientado a objetos

• Distribuido y dinámico

• Robusto

• Seguro

• Multitarea

• Portable

La mayoría de los lenguajes de programación se caracterizan por ser interpretados o


compilados, lo que determina la manera en como serán ejecutados en una computadora.

Java tiene la característica de ser al mismo tiempo compilado e interpretado. El


compilador es el encargado de convertir el código fuente de un programa en un código
intermedio llamado bytecode que es independiente de la plataforma en que se trabaje y
que es ejecutado por el intérprete de Java que forma parte de la Máquina Virtual de
Java.

Ing. Alberto Moreno


UTP -4-

La plataforma Java

Una plataforma es el ambiente de hardware o software en el cual se ejecutan los


programas. En general, la mayoría de las plataformas pueden ser descritas como una
combinación de hardware y sistema operativo. Algunas de las plataformas más
populares son Windows, Solaris, Linux y MacOS.

La plataforma Java difiere de las anteriores en que ésta es una plataforma basada
únicamente en software que corre por encima de las plataformas basadas en hardware.

La plataforma Java consta de dos componentes:

• La Máquina Virtual de Java (JVM)

• La Interfaz de Programación de Aplicaciones de Java (API Java)

A continuación se muestra una representación de los elementos que forman parte de la


plataforma Java.

• javac. Es el compilador de Java. Se encarga de convertir el código fuente escrito


en Java a bytecode.

• java. Es el intérprete de Java. Ejecuta el bytecode a partir de los archivos class.

• appletviewer. Es un visor de applets. En la mayoría de las ocasiones puede


utilizarse en lugar de un Navegador Web.

• javadoc. Se utiliza para crear documentación en formato HTML a partir de el


código fuente Java y los comentarios que contiene.

Ing. Alberto Moreno


UTP -5-

• javap. Es un desensamblador de Java.

• jar. Es una herramienta utilizada para trabajar con los archivos JAR.

Compilación y ejecución de programas Java

Uso del JDK para construir aplicaciones

2.- Sintaxis de Java


La sintaxis de un lenguaje define cómo se usarán las palabras claves, los operadores y
las variables para construir y evaluar expresiones. La sintaxis de Java especifica como
se escribirán los siguientes elementos:

• Comentarios.

• Identificadores.

• Palabras clave.

• Literales.

• Expresiones y operadores.

• Variables y tipos de datos.

• Bloques y sentencias.

Ing. Alberto Moreno


UTP -6-

Comentarios

Java ofrece tres tipos de comentarios: dos para comentarios regulares en el código
fuente y uno para la documentación especial del sistema javadoc.

• Comentarios de varias líneas.

Los comentarios de varias líneas se incluyen entre los símbolos /* y */, como en
C y C++.

/*
Este es un ejemplo de
un comentario de varias
líneas.
*/

• Comentarios de una sola línea.

Para comentariar una sola línea se utiliza la doble diagonal //. El comentario se
inicia cuando se encuentra la doble diagonal y continua hasta el final de la línea.

// Este es un comentario de una sola linea


//Este es otro comentario

• Comentarios para documentación.

Realmente este tipo de comentario es el mismo que el de varias líneas con la


diferencia de que la información que contenga será usada para un procesamiento
especial que lleva a cabo la herramienta javadoc.

Se distingue del comentario de varias líneas porque se agrega un asterisco


adicional al inicio del comentario.

Ejemplo:

/**
Este tipo de comentarios
los utiliza la
herramienta javadoc
*/

Palabras clave

La siguiente tabla muestra las palabras claves de Java, éstas son reservadas y no pueden
ser utilizadas como identificadores.

abstract default if private this


Boolean do implements protected throw
Break double import public throws

Ing. Alberto Moreno


UTP -7-

Byte else instanceof return transient


Case extends int short try
catch final interface static void
Char finally long strictfp** volatile
class float native super while
const* for new switch
continue goto* package synchronized

* Son palabras claves de Java que no son usadas actualmente.


** Palabra clave agregada en Java 2

true, false, and null no son palabras claves pero son palabras reservadas, así que
tampoco pueden ser utilizadas como identificadores.

Literales

Una literal es un valor constante formado por una secuencia de caracteres. Cualquier
declaración en Java que defina un valor constante -un valor que no pueda ser cambiado
durante la ejecución del programa- es una literal.

Son ejemplos de literales los números, los caracteres y las cadenas de caracteres.

• Literales numéricas
Se pueden crear literales numéricas a partir de cualquier tipo de dato primitivo.

Ej.
• 123 //literal int
• 123.456 //literal double
• 123L //literal long
• 123.456F //literal flota

• Literales booleanas :

Las literales boolenas consisten de las palabras reservadas true y false.

• Literales de caracteres

Las literales de caracteres se expresan por un solo caracter entre comillas


sencillas

Ej. 'a', '%', '7'

Ing. Alberto Moreno


UTP -8-

• Literales de cadena

Una cadena es una combinación de caracteres. Las cadenas en Java son instancias
de la clase String, por ello cuentan con métodos que permiten combinar, probar y
modificar cadenas con facilidad.
Las literales de cadena se representan por una secuencia de caracteres entre comillas
dobles.

Ej.
"hola", "cadena123", "12345"

Expresiones y Operadores

• Expresión

Una expresión es una combinación de variables, operadores y llamadas de


métodos construida de acuerdo a la sintaxis del lenguaje que devuelve un valor.

El tipo de dato del valor regresado por una expresión depende de los elementos
usados en la expresión.

• Operadores

Los operadores son símbolos especiales que por lo común se utilizan en


expresiones.

La tabla siguiente muestra los distintos tipos de operadores que utiliza Java.

Operador Significado Ejemplo

Operadores aritméticos

+ Suma a+b

- Resta a-b

* Multiplicación a*b

/ División a/b

% Módulo a%b

Operadores de asignación

Ing. Alberto Moreno


UTP -9-

= Asignación a=b

+= Suma y asignación a += b (a=a + b)

-= Resta y asignación a -= b (a=a - b)

*= Multiplicación y asignación a *= b (a=a * b)

/= División y asignación a / b (a=a / b)

%= Módulo y asignación a % b (a=a % b)

Operadores relacionales

== Igualdad a == b

!= Distinto a != b

< Menor que a<b

> Mayor que a>b

<= Menor o igual que a <= b

>= Mayor o igual que a >= b

Operadores especiales

++ Incremento a++ (postincremento)


++a (preincremento)

-- Decremento a-- (postdecremento)


--a (predecremento)

(tipo)expr Cast a = (int) b

+ Concatenación de cadenas a = "cad1" + "cad2"

. Acceso a variables y métodos a = obj.var1

() Agrupación de expresiones a = (a + b) * c

La tabla siguiente muestra la precedencia asignada a los operadores, éstos son listados
en orden de precedencia.

Los operadores en la misma fila tienen igual precedencia

Operador Notas

. [] () Los corchetes se utilizan para los

Ing. Alberto Moreno


UTP -10-

arreglos

++ -- ! ~ ! es el NOT lógico y ~ es el
complemento de bits

new (tipo)expr new se utiliza para crear instancias de


clases

* / % Multiplicativos

+- Aditivos

<< >> >>> Corrimiento de bits

< > <= >= Relacionales

== != Igualdad

&& AND lógico

|| OR lógico

?: Condicional

= += -= *= /= %= &= ^= |= <<= Asignación


>>= >>>=

Ejemplos demostrativos:

public class PrimerPrograma {

public static void main(String[ ] args) { System.out.println("Hola, mi primer


programa");
}
}

Explicacion .-
public class PrimerPrograma
Nombre de la clase ., coincide con el nombre del archivo.

public static void main


La función principal equivalente a la función main de C/C++

String[ ] argv
Permite de recuperar argumentos transmitidos al programa al momento de su
lanzamiento

System.out.println(“Hola … ")
Método de visualización en la ventana consola

Ing. Alberto Moreno


UTP -11-

Inicializacion y constantes
Pensar a la inicialización al riesgo de una error de compilación
int n; System.out.println(" n = " + n);
Inicialización
Una variable puede recibir un valor inicial al momento de su declaración :

int n = 15;
boolean b = true

Este instrucción tiene el mismo papel :

int n;
n = 15; boolean b; b = true;

Constantes:
Son variables cuyas valor cual se puede afectar una sola vez
No pueden ser modificadas
Son definidas con la palabra clave final
final int n = 5;
final int t;
...
t = 8;
n = 10; // error : n esta declarado final

Ejercicios desarrollados:
1.- Se tienen como datos la base y altura de un triangulo rectángulo , calcular su
hipotenusa.

public class demo2 {

public static void main(String[] args) {


// declaracion de variables
double base=10.6,altura=15,hipo=0;
int can;
hipo=Math.sqrt(base*base+altura*altura);
System.out.print("cantidad "+can);
System.out.print("\n La hipotenusa es "+hipo);
System.out.print("\n de base="+base+" altura="+altura);

2.- Se tienen como datos los tres lados de cualquier triangulo , calcular su area:
public class demo3 {

public static void main(String[] args){


double lado1=14,lado2=5,lado3=6, peri,area;
peri=(lado1+lado2+lado3)/2;

Ing. Alberto Moreno


UTP -12-

area=Math.sqrt(peri*(peri-lado1)*(peri-lado2)*(peri-lado3));
System.out.print("area del triangulo "+area);

3.- Se tiene un numero de tres digitos mostrar la suma de sus digitos.

public class demo4 {

public static void main(String[] args){


int num=345, uni, dec, cen ,sm;
cen=num/100;
dec=(num%100)/10;
uni=(num%100)%10
sm=cen+uni+dec;
System.out.print("La suma de sus digitos: "+sm);
}

ENUNCIADO DEL PROBLEMA:

PASOS PARA CREAR UN PROYECTO DENTRO DEL PROGRAMA:

1)Crear un proyecto para windows

2) En seguida observaremos la siguiente pantalla, donde digitaremos el nombre del

CLIK
Luego en Java
Aplication

CLIK

proyecto:

Ing. Alberto Moreno


UTP -13-

No olvidar
guardar dentro de
“AlumnoUtp”

CLIK

3)

CLIK

Ing. Alberto Moreno


UTP -14-

4) Enseguida digitamos el código correspondiente del programa.

Es importante
digitar la librería
correspondiente

Ing. Alberto Moreno


UTP -15-

5) Una vez digitado el algoritmo, pasamos a compilar(F9) y luego ejecutarlo (shift + F6)
y nos brindara la siguiente pantalla donde apreciaremos los errores de la codificación..

6) Una vez compilada el programa digitaremos los datos de los trabajadores


correspondiente, como observaremos en los siguientes cuadros.

Ing. Alberto Moreno


UTP -16-

Ing. Alberto Moreno


UTP -17-

7) Como apreciamos el cuadro de resultados será lo siguiente.

Ing. Alberto Moreno


UTP -18-

DIAGRAMA DE ACTIVIDADES nos va permitir tener una mejor visión sobre los
procesos que vamos a desarrollar en el programa , la diagramacion puede elaborase
empleando el Rational Rose o el UML.

Ing. Alberto Moreno


UTP -19-

Ejecución condicional

El formato general es:

if (expresion_booleana)
sentencia
[else
sentencia]

sentencia (a todo lo largo de este capítulo) puede ser una sola sentencia o un
bloque de sentencias separadas por ; y enmarcadas por llaves { y }. Es decir

if (expresion_booleana) {
sentencia;
sentencia;
. . .
}
else {
sentencia;
sentencia;
. . .
}

Ing. Alberto Moreno


UTP -20-

Ambigüedad

if (a) if (b) S1; else S2;


significa
if (a) { if (b) S1; else S2; }

expresion_booleana es una expresión que se evalua como true o false (es


decir, de tipo booleano). Si el resultado es true la ejecución bifurca a la
sentencia que sigue al if . En caso contrario se bifurca a la sentencia que sigue
al else.

Los corchetes en el formato anterior indican que la clausula else es opcional.

Ing. Alberto Moreno


UTP -21-

Ejemplos de instrucción if else

1.- Se tiene como datos de ingreso los datos de un triángulo (lado1, lado2 y
lado3) en caso que forme triángulo calcular su área, de lo contrario muestre un
mensaje de error, no se forma triángulo. Para formar un triángulo un lado
siempre tiene que ser menor a la suma de los otros dos lados. Y su área de la
siguiente manera:

L1 + L 2 + L3
P=
2

Area = p( P − L1)( P − L 2)( P − L3)

public class demo3 {

public static void main(String[] args){


double lado1=14,lado2=5,lado3=6, peri,area;
if(lado1+lado2>lado3 && lado3+lado2>lado1 && lado3+lado1>lado2)
{
peri=(lado1+lado2+lado3)/2;
area=Math.sqrt(peri*(peri-lado1)*(peri-lado2)*(peri-lado3));
System.out.print("area del triangulo "+area);

}
else{
System.out.print("No forma triangulo");
}

}
}

Ing. Alberto Moreno


UTP -22-

Ejercicios propuestos 1.-


1.- Datos del programa descripción de un producto, el precio y la cantidad
vendida, calcular y mostrar:
a. Importe por la compra, multiplique precio por la cantidad vendida.
b. Impuesto general a las ventas (Igv), es 19% del importe de compra.
c. Importe final por la compra, sume el importe de compra más el Igv.

2.- Dato un número de cuatro cifras, calcular y mostrar:


a. Suma de las cifras
b. Promedio de las cifras.

3.- Desarrolle un algoritmo para la telefónica que permita mostrar el pago


por consumo telefónico; Datos del programa código del usuario, el número
telefónico y la cantidad de minutos utilizados.
Visualice el código del usuario, el importe por los minutos utilizados, el IGV
y el pago total.

Tenga en cuenta que la empresa cobra S/0.30 por minuto utilizado, S/ 48.00
de renta básica y que el IGV es 19% respecto al importe por minutos.

4.- Elabore un algoritmo para EDELNOR,datos el código del suministro y la


cantidad de kilowatts consumidos. Calcule y muestre los siguientes pagos:
a. Importe inicial.
b. El pago del 3.5% por alumbrado publico.
c. El pago del 1.8 por mantenimiento.
d. El pago del 4.8 por reajuste de acuerdo a ley.
e. El 19% por pago del IGV
f. El pago total.
Los porcentajes son respecto al importe inicial.

Ing. Alberto Moreno


UTP -23-

Considerar que el Precio por Kilowats es S/ 0.09 .

5.- Se desea obtener medallas a partir de una plancha rectangular metálica


, los datos de ingreso del programa son los lados de la plancha ancho y
altura y el radio de la medalla expresado en centímetros, calcular :
- Numero de medallas circulares
- Área Sobrante
Condicionales

6.-Datos del programa el nombre de un trabajador sus horas trabajadas y


tarifa normal, Si tiene horas extras (horas trabajadas mayores a 48 hrs.)
calcular y mostrar:
a. Pago normal
b. Horas extras
c. Pago extras será 10% de incremento de la tarifa normal por cada hora
extra.
d. Sueldo final.

7.- Dato del programa un numero cualquiera, solo si el número es múltiplo


de 2 y 5 mostrar:
a. El doble del número ingresado.
b. Raíz cúbica del número ingresado.
c. El cubo del número ingresado.

8.- Datos del programa el nombre de un cliente, condición de pago (E:


efectivo, C:crédito) y el precio del producto. Calcular y mostrar:
a. Descuento, será 10% del precio siempre que la compra se efectúe en
efectivo, sino cero.
b. Recargo, será 3% del precio si la compra fue a crédito, sino cero.
c. Precio final

9.- Ingresar como datos las horas y minutos respecto a las manecillas de las
agujas de un reloj, se pide calcular el ángulo que forman estas manecillas.
Por ejemplo horas= 3 y minutos= 30 ángulo formado =90

10.-Ingrese por teclado tres números cualquiera, mostrar los números


ordenados ascendentemente. Considerar que los números ingresados son
diferentes.

11.- Ingrese por teclado el nombre y dos notas (parcial y final de peso doble),
calcular su promedio y una observación de acuerdo a:

Promedio Clasificación
00 – 05 Deficiente
06 – 10 Malo
11 – 13 Regular
14 – 17 Bueno
18 – 20 Excelente

Ing. Alberto Moreno


UTP -24-

Procesos Repetitivos.-

Iteraciones con while


Sintaxis formato 1:

while (expresion_booleana)
sentencia

Sintaxis formato 2:

do
sentencia
while (expresion_booleana)

La sentencia o bloque se sentencias (se aplica la misma idea que para el if-else) se
ejecuta mientras que la expresion_booleana se evalue como true

La diferencia entre ambos formatos es que en el primero la expresión se evalua al


principio del bloque de sentencias y en el segundo se evalua al final

Iteraciones con for


El formato es:

for ( inicializacion ; expresion_booleana ; step )


sentencia

inicializacion es una sentencia que se ejecuta la primera vez que se entra en el


bucle for . Normalmente es una asignación. Es opcional.

expresion_booleana es una expresión que se evalua antes de la ejecución de la


sentencia, o bloque de sentencias, para cada iteración. La sentencia o bloque de
sentencias se ejecutan mientras que la expresion_booleana se evalue como
cierta. Es opcional.

step es una sentencia que se ejecuta cada vez que se llega al final de la sentencia o
bloque de sentencias. Es opcional.

Una utilización clásica de un bucle de tipo for se muestra a continuación para evaluar un
contador un número fijo de veces:

Ing. Alberto Moreno


UTP -25-

for ( int i = 1 ; i <= 10 ; i++ )


sentencia

La sentencia (o bloque de sentencias) se evaluará 10 veces. En cada ejecución (pasada)


el valor de la variable i irá variando desde 1 hasta 10 (inclusive). Cuando salga del
bloque de sentencias i estará fuera de su ámbito (porque se define en el bloque for).

Ejemplos:

1.- Ingresando un numero entero de cualquier longitud que muestre la suma de


sus digitos:
public class demo1 {

public static void main(String[] args){


int num=234567378; // sea este numero
int r,sm=0;
String cad="";
while(num>0){
r=num%10;
sm += r;
cad=cad+r;
num=num/10;

}
System.out.print("la suma de los digitos="+sm);
System.out.print("\n numero invertido="+cad);

}
}

2.- Ingresar cierta cantidad de bolas de billar , obtener las superficies


formadas y el numero de bolas que sobran , cada superfice es una base
triangular .

public repetir02 {
public static void main(String[] args) throws Exception {
int doble=0,nbolas, ns=0, c=1,sm=0;

BufferedReader tecla=new BufferedReader(new


InputStreamReader(System.in));
System.out.println("ingrese numero de bolas");
nbolas=Integer.parseInt(JOptionPane.showInputDialog("ingrese numero de
bolas"));
//nbolas=Integer.parseInt(tecla.readLine());
System.out.println("ingrese superficie");

Ing. Alberto Moreno


UTP -26-

ns=Integer.parseInt(tecla.readLine());
while(sm<nbolas){
doble=c*c;
sm=sm+doble;
ns ++;
c=c+1;
}
sm=sm-doble;
ns--;
int sobran;
sobran=nbolas-sm;
System.out.println("superfices="+ns);
System.out.print("sobran="+sobran);

Ejercicios Propuestos 2.-

1.- Ingresar 10 números por teclado luego muestre todos los números ingresados y
además muestre el mayor numero y el segundo mayor
por ejemplo la salida de 10 números será:

Ing. Alberto Moreno


UTP -27-

2.- Realizar un programa que permita calcular el pago de matricula de un alumno los
datos de ingreso son la Escala (A,B y C) el promedio ponderado, y la cantidad de
créditos; Ingresar los datos hasta que se ingrese por teclado el Carácter * en la Escala.
Las condiciones:

El pago por crédito es de acuerdo a la escala : A=>S/ 20.0 , B=>S/. 16 , y C =>S/12.0


Además se hará un descuento del 15% del pago si su promedio es mayor a 15 y se
encuentra entre 12-15 solo un 10%.

3.- En el mundial de la sub_17 de corea se desea saber quien fue el primer, y segundo
goleador y ademas a que pais pertenece, los datos a ingresar son :
Nombre del pais, nombre del jugador y la cantidad de goles que hizo , ingresar los
datos hasta que ingrese * en el país.

4.- ingresar un conjunto de trabajadores hasta que se ingrese en la categoría un * , el


pago hora para la categoría 1(empleado) 12 y descuento es 10% y para obrero (2) es
10 soles , descuento 8% , mostrar el pago total y descuento.
Datos de ingreso , horas trabajadas y categoría

5.- ingrese un numero luego muestre dicho numero en romanos .

6.- ingrese un numeró de cinco cifras luego muestre si es capicúa y un mensaje de error
en caso que se ingrese un numero de diferente longitud.
7.- Ingrese un numero entero de cualquier longitud , luego muestre:
a) La suma de sus dígitos
b) El numero ordenado de manera ascendente
c) La suma de los cuadrados de los dígitos pares.

Ejemplo si el numero es : 45672


La suma de sus dígitos>24
Ordenado => 24567

8.- Se desea formar una pirámide de base cuadrada con una cierta cantidad de bolas de
billar , cada superficie esta formada por un numero cuadrado ( 12, 22, 32 ,...) , Mostrar
la cantidad de superficies formadas y el numero de bolas que sobran.
Por ejemplo si se ingresa 20 bolas : se forman 3 superficies y sobran 6 bolas.

9.- Mostrar todos los números perfectos menores a 1000 ; un numero es perfecto cuando
la suma de sus divisores es el mismo numero , sin incluir el mismo numero, por ejemplo
el 6 sus divisores 1+2+3

10.- Mostrar todos los números primos del 1-100

11.-Pasar un numero del sistema decimal a Hexadecimal

12.- Un automóvil viaja a una velocidad promedio de 55km por hora durante cuatro
horas. Escriba un programa que muestre la distancia, en km, que el auto ha recorrido
después de cada media hora, 0.5 hora , 1hora, 1.5, 2,4, ... horas hasta el final del
viaje.

Ing. Alberto Moreno


UTP -28-

13.- Una pelota de golf se lanza desde un avión. La distancia, d, que la pelota cae en t
segundos está dada por la ecuación d = (1/2) * g*t 2 donde g es la aceleración de la
gravedad y es igual a 9.81 m/seg 2 . Escribir un programa que muestre la distancia a
la que cae la pelota en cada intervalo de un segundo durante diez segundos y la
distancia total que la pelota ha recorrido al final de cada intervalo. La salida debe
contemplar la siguiente tabla:
Tiempo(segundos) Distancia en el intervalo actual (metros) Distancia total
0 0.0 0.0
1 4.905 4.905

14.- Se compra una computadora a crédito , que puede ser en 6 , 12 o 18 meses , los
intereses varían de acuerdo a los meses:
Meses % interés
6 20
12 30
18 40
Mostrar un calendario de pagos , de acuerdo a la siguiente tabla:
Los datos de ingreso
Precio Final : ........... Son:
Mes Cuota Mensual Saldo Precio de la computadora
===================================== y el tipo de pago
1 ...... ......
2 ..... ......
Arrays

Declaración y acceso

Un array es una colección ordenada de elementos del mismo tipo, que son accesibles a
través de un índice.

Un array puede contener datos primitivos o referencias a objetos.

Los arrays se declaran:

[modificadores] tipo_variable [ ] nombre;

Por ejemplo:

int [ ] a;
Punto [ ] p;

La declaración dice que a es un array de enteros y p un array de objetos de tipo Punto.


Más exactamente a es una referencia a una colección de enteros, aunque todavía no se
sabe cuantos elementos tiene el array. p es una referencia a una colección de referencias
que apuntarán objetos Punto.

Un array se crea como si se tratara de un objeto (de hecho las variables de tipo array son
referencias):

Ing. Alberto Moreno


UTP -29-

a = new int [5];


p = new Punto[3];

En el momento de la creación del array se dimensiona el mismo y se reserva la memoria


necesaria.

También puede crearse de forma explícita asignando valores a todos los elementos del
array en el momento de la declaración, de la siguiente forma:

int [ ] a = { 5 , 3 , 2 };

El acceso a los elementos del array se realiza indicando entre corchetes el elemento del
array que se desea, teniendo en cuenta que siempre el primer elemento del array es el
índice 0. Por ejemplo a[1]. En este ejemplo los índices del array de tres elementos
son 0, 1 y 2. Si se intenta usar un índice que está fuera del rango válido para ese array se
produce un error (en realidad una excepción: las excepciones se tratan en un capítulo
posterior) de 'Indice fuera de rango'. En el ejemplo anterior se produce esta excepción si
el índice es menor que 0 o mayor que 2.

Se puede conocer el número de elementos de un array usando la variable length. En


el ejemplo a.length contiene el valor 3.

Un array, como cualquier otra referencia puede formar parte de la lista de parámetros o
constituir el valor de retorno de un método. En ambos casos se indica que se trata de un
array con los corchetes que siguen al tipo. Por ejemplo:

String [ ] metodoConArrays ( Punto [ ] ) { . . }

El método metodoConArrays recibe como parámetro un array de Puntos y devuelve un


array de Strings. El método podría invocarse de la siguiente forma:

Punto p [ ] = new Punto [3];


. . .
String [ ] resultado = metodoConArrays(p);

Arrays multidimensionales

Es posible declarar arrays de más de una dimensión. Los conceptos son los mismos que
para los arrays monodimensionales.

Por ejemplo:

int [ ][ ] a = { { 1 , 2 } , { 3 , 4 } , { 5 , 6 } };
int x = a[1][0]; // contiene 3
int y = a[2][1]; // contiene 6

Se pueden recorrer los elementos de un array multidimensional, de la siguiente forma:

Ing. Alberto Moreno


UTP -30-

int [ ][ ] a = new int [3][2];


int x = a.length;
int y = a[0].length;
for ( int i = 0 ; i < x ; i++ )
for ( int j = 0 ; j < y ; j++)
a[i][j] = i * j;

Obsérvese en el ejemplo la forma de acceder al tamaño de cada dimensión del array.

Funciones/Metodos De Usuario
Las funciones/metodos son trozos de código que encapsulan cierta funcionalidad
especial.
En general tienen datos de entrada y datos de salida (pueden no tenerlos).
Son muy similares a la idea de una función en matemáticas:

funcion(x ) = x 2 + 3
Esta función tiene una definición y puede ser evaluada con distintos valores, por
ejemplo si hacemos

funcion(5)

sabemos que el resultado seria 28.

La función matemática funcion(x ) = x 2 + 3 podría verse en JAVA como:

funcion( x)
{
resultado = x * x + 3;
¡
}

veremos que es un poco más complicado....


I La idea seria poder usar la función en un código cualquiera, por ejemplo:

Ing. Alberto Moreno


UTP -31-

int x, y;

x = 1 + funcion(2);
y = funcion(x); System.out.println(x); System.out.println(y);

Las funciones en JAVA tienen varias partes importantes en su definición:


Nombre funcion
Nombres de los datos de entrada x
Tipos de datos de entrada ???
Tipo de dato de retorno ???
C´odigo v´alido interno
Instrucci´on de retorno ???
En JAVA se un poco m´as como:

int funcion(int x)
{
int resultado = x * x + 3;
return resultado;
}

adicionalmente tenemos que empezar la función con public static (esto permite que la
función sea usado directamente sin necesidad de crear el objeto.
Un ejemplo completo
class EjemploFuncion
{
public static void main(String[] args)
{
int x, y;
x = 1 + funcion(2);
y = funcion(x) * funcion(x - 2);
System.out.println(x); System.out.println(y); System.out.println( funcion(0) );
}

public static int funcion(int x)


{
int resultado;
resutado = x * x + 3;
return resultado;
}
}
ejemplo 2.- encontrar el factorial y la potencia de un numero sin utilizar la clase Math
Ejemplo dos funciones
class Ejemplo
{
public static void main(String[] args)
{
int n, i;
System.out.println("Dime un entero positivo");
n = In.readInt();

Ing. Alberto Moreno


UTP -32-

System.out.println( n + "! = " + factorial(n) ); System.out.println( n + "^" + n


+ " = " + potencia(n,n));
}

public static int potencia(int base, int exponente)


{
int resultado = 1;
int i;
for(i = 1; i <= exponente; i++)
{ resultado = resultado * base; }
return resultado;
}

public static int factorial(int numero)


{
int factor = 1;
for(int i =1; i<=numero; i++)
{ factor = factor * i; }
return factorial;
}

Ing. Alberto Moreno


UTP -33-

Ejemplo2.-
public class metodos {

public static void main(String[] args){


int[] a={12,3,5,7,9};

System.out.println("la suma es "+suma(a)); Crear los siguientes métodos:


ordena(a); a) pasando un vector de enteros que
//imprimeir ordenados devuelva su suma.
int k;
for(k=0;k<a.length;k++){ b ) Pasando un vector que permita
System.out.println("\n " +a[k]); ordenar dicho vector de forma ascdente.

}
}

static int suma(int[] vec){


int sm=0,f;
for(f=0; f<vec.length;f++){
sm += vec[f];
}
return sm;

static void ordena(int[] vec){


int k,aux,j,x;
x=vec.length;
for(k=0;k<x-1;k++)
for(j=k+1;j<x;j++)
{
if(vec[k]>vec[j]){
aux=vec[k];
vec[k]=vec[j];
vec[j]=aux;
}
}

Ing. Alberto Moreno


UTP -34-

Ejercicios Propuestos 3

Realizar Las Siguientes cuyos Nombres y parámetros por valor Son:

1.- Función Acirculo pasando como valor un radio devuelva su área

2.- Función Acuadrado pasando como valor un lado devuelva su área

3.- Función Cilindro pasando como valores el radio y su altura devuelva su área

4.- Función Hipotenusa pasando como valor la base y la altura devuelva su


hipotenusa.

5.- Función Triangulo pasando como valor tres lados de un triangulo en caso que forme
triángulo que devuelva su área de lo contrario que devuelva un valor -1

6.- Función Hexadecimal que pasando un valor numérico que devuelva dicho numero
en el sistema hexadecimal (como cadena)

7.- Función Binario pasando como valor un numero que lo devuelva en el sistema
binario.(el valor es como cadena).

8.- Función Divisores pasando un numero que devuelva el numero de sus divisores

9.- Función Primo pasando un numero entero que devuelva un valor lógico si es True
es primo y False si no lo es.

10.- Función Left(Cad,n) pasando una cadena y numero de caracteres que devuelva los
carectares hacia la izquierda hasta el numero indicado.

11.- Función Right(Cad,n) que extraiga caracteres hacia la derecha.

12.- Función CUENTAV pasando una cadena , que devuelva el numero de vocales que
contiene dicha cadena..

Nota: A cada función elaborada ponga un nombre adecuado


13.- Pasando un Numero que devuelva el factorial de dicho numero

14.-Pasando un Valor entero de grados centígrado y un carácter( “R”, “K”,”F”) que


representan Ranking, kelvin y farenheit respectivamente ,devuelva su conversión. Al
grado seleccionado.

15..-Pasando un numero entero que devuelva dicho numero en romanos (el valor
ingresado debe ser menor a 1000)

16.- Pasando un numero de cualquier longitud puede ser hasta millones , que devuelva
dicho numero en Letras.
Cletras(4567234)=> Cuatro millones quinientos sesenta y siete mil doscientos treinta
y cuatro.

Ing. Alberto Moreno


UTP -35-

18.- Pasando un vector de enteros que devuelva la suma de los números.

19- Pasando una vector que devuelva el mismo vector pero ordenado.

20.- pasando un vector y un elemento que realice la búsqueda de dicho elemento en el


vector si lo encuentra devuelve true de lo contrario false.

Solo entregar el resultado:


21. ¿Cuál es el resultado del siguiente programa?
class Ejercicio {
public static void main(String [] args) {
int[] a={3,4,5};
int [] b=a;
b[1]=3;
a=metodo1(a ,b);
for (int i=0; i<a.length;i++)
System.out.print(a[i]+" "+b[i]+" ");
}
public static int [] metodo1(int [] d, int [] e) {
e[1]=4;
int [] c={0,0,0};
for (int i=0; i< d.length; i++)
c[i]=d[i]+e[i];
return c;
}//fin main
}//fin clase

22. ¿Cuál es el resultado del siguiente programa?


class Ejercicio {
public static void main(String [] args) {
int [] Valores1 ={9, 48, 5, 3, 29, 62};
int [] Valores2 ={45, 1, 33};
metodo1(Valores1 [4]);
metodo1(Valores2 [2]);
metodo2(Valores2);
Valores1=metodo3(Valores2);
System.out.print(Valores1[0]);
for (int i=1; i<Valores2.length;i++)
System.out.print(" "+Valores1[i]);
}
public static void metodo1(int numero) {
numero = 0;
numero=numero+10;
}
public static void metodo2(int [] lista) {
lista[1]=lista[2];
}
public static int [] metodo3(int [] lista) {
for (int i=0; i<lista.length;i++)
lista[i]=lista[i]+i;
return lista;
}
}

Ing. Alberto Moreno


UTP -36-

// una clase simple

public class clase02 {


public static void main(String[] args) {
// TODO code application logic here
Obrero per=new Obrero();
per.nom="JOse ";
per.horas=67; Crear una clase obrero con los atributos:
per.sec='B'; Nombre , horas trabajadas y sección de
per.calculo(); trabajo( A o B)
- Crear el método calculo
} - El pago por hora es de acuerdo a la
} sección si A su pago hora es de 8 soles si
es B es de 7.4 soles
class Obrero{
String nom;
double horas;
char sec;
void calculo(){
double afp,pt;

if(sec=='A')
pt=this.horas*8;
else
pt=this.horas*7.4;
afp=pt*0.11;
System.out.print("\npago total ="+pt);
System.out.print("\n Descuento por afp="+afp);
}

Ing. Alberto Moreno


UTP -37-

MANEJO DE CADENAS

Clase Strings
Una secuencia de datos del tipo carácter se llama un string (cadena) y en el entorno Java
está implementada por la clase String (un miembro del paquete java.lang).

String[] args;

Este código declara explícitamente un array, llamado args, que contiene objetos del tipo
String. Los corchetes vacios indican que la longitud del array no se conoce en el
momento de la compilación, porque el array se pasa en el momento de la ejecución.

El segundo uso de String es el uso de cadenas literales (una cadena de caracteres entre
comillas " y ").

"Hola mundo!"

El compilador asigna implicitamente espacio para un objeto String cuando encuentra


una cadena literal.

Los objetos String son inmutables - es decir, no se pueden modificar una vez que han
sido creados.

El paquete java.lang proporciona una clase diferente, StringBuffer, que se podrá utilizar
para crear y manipular caracteres al vuelo.

Concatenación de Cadenas

Java permite concatenar cadenas fácilmente utilizando el operador +. El siguiente


fragmento de código concatena tres cadenas para producir su salida.

"La entrada tiene " + contador + " caracteres."

Dos de las cadenas concatenadas son cadenas literales: "La entrada tiene " y "
caracteres.". La tercera cadena - la del medio- es realmente un entero que primero se
convierte a cadena y luego se concatena con las otras.

Funciones cadena

Tipo de Dato
Sintaxis del metodo y descripciónn
Devuelto

Ing. Alberto Moreno


UTP -38-

char charAt(int index)


Devuelve un caracter del indice especificado
int compareTo(String anotherString)
Compara dos cadenzas en longitud y contenido lexicografico .
String concat(String str)
Cancoatena dos cadenas.
boolean equals(Object anObject)
devuelve true si las dos cadenzas son iguales
int indexOf(String str)
Devuelve la posicion de la primera ocurrencia encontrada.
int lastIndexOf(String str)
Similar al anterior pero devuelve la posicion de la ultima ocurrencia
encontrada..
int length()
devuelve la longitud de la cadena
String replace(char oldChar, char newChar)
remplaza un caracter con un Nuevo caracter en toda la cadena.
String replaceAll(String regex, String replacement)
similar al anterior pero trabaja con cadenas.
String replaceFirst(String regex, String replacement)
Replaces the first substring of this string that matches the given
regular expression with the given replacement.
String[] split(String regex)
divide una cadena por medio de un carácter común asignándolo a
un vector.
String substring(int beginIndex)
Retorna una cadena desde la posicion indicada hasta la ultima
posicion.
String substring(int beginIndex, int endIndex)
devuelve una cadena desde la posición indicada hasta la diferencia de los
indices especificados.
String toLowerCase()
Convierte toda la cadena ha letras minusculas
String toUpperCase()
Convierte toda la cadena a letras mayusculas..
String trim()
Returns a copy of the string, with leading and trailing whitespace
omitted.

package

Ing. Alberto Moreno


UTP -39-

Un package es una agrupación de clases afines. Equivale al concepto de


librería existente en otros lenguajes o sistemas. Una clase puede definirse
como perteneciente a un package y puede usar otras clases definidas en ese o
en otros packages.

Los packages delimitan el espacio de nombres (space name). El nombre de


una clase debe ser único dentro del package donde se define. Dos clases con
el mismo nombre en dos packages distintos pueden coexistir e incluso pueden
ser usadas en el mismo programa.

Una clase se declara perteneciente a un package con la clausula package,


cuya sintaxis es:

package nombre_package;

La clausula package debe ser la primera sentencia del archivo fuente.


Cualquier clase declarada en ese archivo pertenece al package indicado.

Por ejemplo, un archivo que contenga las sentencias:

package miPackage;
...
class miClase {
...

declara que la clase miClase pertenece al package miPackage.

La agrupación de clases en packages es conveniente desde el punto de vista


organizativo, para mantener bajo una ubicación común clases relacionadas que
cooperan desde algún punto de vista.

Claúsula import

Cuando se referencia cualquier clase dentro de otra se asume, si no se indica


otra cosa, que ésta otra está declarada en el mismo package. Por ejemplo:

package Geometria;
...
class Circulo {
Punto centro;
...
}

En esta declaración definimos la clase Circulo perteneciente al package


Geometria. Esta clase usa la clase Punto. El compilador y la JVM asumen que
Punto pertenece también al package Geometria, y tal como está hecha la
definición, para que la clase Punto sea accesible (conocida) por el compilador,
es necesario que esté definida en el mismo package.

package GeometriaBase;
class Punto {

Ing. Alberto Moreno


UTP -40-

int x , y;
}

Entonces, para usar la clase Punto en nuestra clase Circulo deberiamos poner:

package GeometriaAmpliada;

import GeometriaBase.*;

class Circulo {
Punto centro;
...
}

Con la claúsula import GeometriaBase.*; se hacen accesibles todos los


nombres (todas las clases) declaradas en el package GeometriaBase. Si sólo
se quisiera tener accesible la clase Punto se podría declarar: import
GeometriaBase.Punto;

La claúsula import simplemente indica al compilador donde debe buscar


clases adicionales, cuando no pueda encontrarlas en el package actual y
delimita los espacios de nombres y modificadores de acceso.

Nombres de los packages

Los packages se pueden nombrar usando nombres compuestos separados por


puntos, de forma similar a como se componen las direcciones URL de Internet.
Por ejemplo se puede tener un package de nombre
misPackages.Geometria.Base.

El API de java está estructurado de esta forma, con un primer calificador (java o
javax) que indica la base, un segundo calificador (awt, util, swing, etc.) que
indica el grupo funcional de clases y opcionalmente subpackages en un tercer
nivel, dependiendo de la amplitud del grupo. Cuando se crean packages de
usuario no es recomendable usar nombres de packages que empiecen por java
o javax.

Clases
Modela una abstracción definiendo propiedades y comportamientos para los
objetos representados.
Propiedades : atributos, variables
Comportamientos : operaciones, métodos
Implementación : Define cómo se proporcionan los servicios en una
clase.
Una abstracción trata de mostrar las propiedades y comportamientos de
un objeto que lo diferencia de otro.

Ing. Alberto Moreno


UTP -41-

•Representa un conjunto de propiedades y métodos de uno o mas objetos


idénticos.
•Todo en Java forma parte de una clase, es una clase o describe cómo
funciona una clase.
•Ejmeplo: Public Class Persona {
}

Objetos
Es una instancia concreta de la abstracción que representa la clase.
Los objetos en Java se manejan por referencias Declaración de una
variable de referencia.
Persona persona1;
Creación del objeto. Operador new.
persona1 = new Persona();
persona2 = new Persona();
Donde: Persona es el nombre de la clase.
El operador new devuelve una referencia al objeto creado.
Persona() es el metodo cosntructor
persona1 y persona2 son objetos o instancias de la clase Persona
Variable = objeto/instancia
Tipo = clase Cuando un objeto pierde su referencia es tomado por el
garbage collector.

Metodo constructor

Es un método especial, que se invoca automáticamente cuando se declara un


objeto, sirve para inicializar el estado del objeto.
Características:
–No tiene tipo de dato
–No pueden devolver un valor–Su nombre coincide con el nombre de la clase
donde se encuentra
–Cuando la clase no tiene un constructor la VM le asigna uno vacío por
default–Puede haber mas de un constructor dentro de una clase
–Se ejecuta cuando invocamos al operador new

Ing. Alberto Moreno


UTP -42-

Estructura de una Clase


<cabecera_de_clase> {
<cuerpo_clase>
}
La cabecera puede tener la siguiente información :
Modificadores de ámbito o accesibilidad.
Modificadores adicionales.
Herencia
Implementación de interfaces.
El cuerpo de la clase puede tener atributos y métodos

[public][final][abstract] class Nombre


{
//propiedades

//metodos
}

default (Sin modificador) : Accesible en el paquete.


public : Accesible en cualquier lugar.
abstract : La clase no puede ser instanciada. Por razones de diseño
o
por contener algún método abstracto. Sirve de base para la
herencia.
final : La clase no puede ser heredada. Son el último nivel

Ing. Alberto Moreno


UTP -43-

<cabecera_de_metodo> ( <lista de parametros>) <throws excepcion> {


<cuerpo_método>
}
La cabecera puede tener la siguiente información :
Modificadores de ámbito o accesibilidad.
Modificadores adicionales.
public : Accesible en todos lados.
protected : Accesibles dentro del paquete que contiene la clase y por todos sus
subclases. Otras clases de otros paquetes no pueden acceder.
default : Accesible solamente dentro del paquete.
private : Accesible solamente dentro de la clase.
OTROS MODIFICADORES
static : Define una variable o método de clase
final : Define una constante o que el método no puede ser sobreescrito.
abstract : Define un método abstracto

Ing. Alberto Moreno


UTP -44-

Los miembros de instancia son los métodos y las variables que pertenecen al objeto.
Los valores de las variables definen el estado del objeto.
Los métodos definen el comportamiento de un objeto. La implementación de los
métodos sí es compartida por todas las instancias.

Los miembros estáticos son los métodos y las variables que pertenecen a la clase.
Se diferencian en la definición por la palabra clave static.
Las variables estáticas son inicializadas cuando se carga la clase en runtime.
Los miembros estáticos pueden ser llamados utilizando el nombre de la clase o a
través de la referencia al objeto

• Variables de tipo simple de datos: El paso de parámetros se realiza siempre por


valor, es decir, el valor del parámetro de llamada no puede ser modificado en el
cuerpo del método ( El método trabaja con una copia del valor utilizado en la
llamada).
• Variables de tipo Objeto (referencias): El valor del parámetro de llamada si
puede ser modificado dentro del método. ( El método trabaja directamente con el
valor utilizado en la llamada).

Es la capacidad de crear una nueva clase a partir de otra clase ya existente.


La nueva clase puede definir nuevos atributos y métodos o modificar los ya
existentes, si como utilizar los atributos o metodos de la clase padre.
La clase padre se denomina superclase y la hija, subclase.
En Java la herencia es lineal (sólo existe un superclase para una subclase)
Utilizamos la palabra clave extends.
Se heredan los métodos permitidos.
Se puede sobreescribir algunos metodos de la superclase

La sobrecarga de métodos nos permite implementar un método de diferente manera.


La firma del método sobrecargado cambia.

public int metodo1(int a);


public int metodo1(int a, String c);

Es necesario cambiar la “firma” del método, no sólo los valores de devolución

Para sobrescribir un método debemos de tener en cuenta :


Debemos revisar el nivel de accesibilidad para comprobar que podemos
sobreescribir el método.
El método debe tener la misma “firma” o declaración que el de la clase
padre.

Ing. Alberto Moreno


UTP -45-

this –permite hacer referencia a elementos de la misma clase


super –permite hacer referencia a elementos de la clase padre

Ejercicios propuestos 4.-


1.- Diseñe e implemente en Java una clase para trabajar con triángulos isósceles. Para
ello, defina las variables de ejemplar mínimas que requiera, proporcione métodos de
consulta, un método constructor e implemente otros métodos para calcular el perímetro
y el área de un triángulo.

2.-Implemente una clase llamado banco ,con los atributos nro de cuenta , nombre del
cliente , tipo de ahorro( D=dólar y S=soles) y el saldo; Implemente los métodos para
deposito , retiro de dinero. y los métodos constructores respectivos.
Esta aplicación impleméntelo :

a) Primero en modo de consola , empleando un ArrayList para almacenar un


conjunto de clientes , se debe elaborar un menú que contemple las siguientes
opciones:
(1) Nuevos ahorristas
(2) Consulta de Saldos
(3) Movimiento de Cuentas
(4) Listado de Ahorristas
(5) Anulación de cuentas
(6) Salir

En la opción 2 se realiza la búsqueda por medio de un numero de cuenta


En la opción 3 se realiza el deposito o retiro a través de un numero de cuenta
actualizando el saldo respectivo.
La anulación también se realiza por medio del nro de cuenta.

b) Realizar la misma aplicación pero empleando formularios.

Ing. Alberto Moreno


UTP -46-

3. ¿Cuál es el resultado del siguiente programa?

class Ejercicio {
public static void main(String [ ] args){
Clase1 obj1=new Clase1();
obj1.imprimir(24.3,5);
}
}
class Clase1 {
private double valor=9.8;
private int x=7;
public void imprimir(double valor, int x) {
System.out.print(valor+” “+this.x);
}
}

4.- 12. ¿Qué imprime el siguiente programa?

class Principal {

public static void main(String[] args) {


Autor autor =new Autor ("Paul", "Auster");
Libro libro= new Libro ("La trilogía de Nueva York", autor); System.out.println
(libro.getTitulo()+" de " +
(libro.getAutor()).toString());
}

class Libro {

private String titulo;


private Autor autor;

public Libro(String titulo, Autor autor) {


this.titulo = titulo;
this.autor = autor;
}

public Autor getAutor() {


return autor;
}

public String getTitulo() {


return titulo;
}

Ing. Alberto Moreno


UTP -47-

class Autor {

private String nombre;


private String apellido;

public Autor (String nombre, String apellido) {


this.nombre = nombre;
this.apellido=apellido;
}

public String toString () {


return nombre+ " " +apellido;
}
}

Ing. Alberto Moreno


UTP -48-

APLIACION GENERAL DE MANTENIMIENTOS EMPLEANDO CLASES

Objetivo.- Que el alumno se capaz de implementar clases y manejo de ArrayList para


almacenar datos para un conjunto de items y a partir de ello realizar las operaciones de
Listado, modificación y eliminación de datos.

Las pantallas a emplear son las siguientes:

Ing. Alberto Moreno


UTP -49-

1.- La opción de anulación es a través del código del empleado :

Ing. Alberto Moreno


UTP -50-

La Modificación de Datos:
También se realiza mediante el código del empleado

Ing. Alberto Moreno


UTP -51-

Los pasos a realizar:


1.- Diagrama de clases:

Ing. Alberto Moreno


UTP -52-

1.- Establecer los paquetes para las clases, inagenes y el paquete de prueba.

Empleado.java
package pack2;

public class Empleado {


private String code;
private String nome;
private char sec;
private double horas;
private double pt;
private static int nro=0;
/** Creates a new instance of Empleado */
public Empleado() {
nro++;
}

public Empleado( String cod,String nom, char sec, double hr ) {


this();

Ing. Alberto Moreno


UTP -53-

this.code=cod;
this.nome=nom;
this.sec=sec;
this.horas=hr;
}

public String getCode() {


return code;
}

public void setCode(String code) {


this.code = code;
}

public String getNome() {


return nome;
}

public void setNome(String nome) {


this.nome = nome;
}

public char getSec() {


return sec;
}

public void setSec(char sec) {


this.sec = sec;
}

public double getHoras() {


return horas;
}

public void setHoras(double horas) {


this.horas = horas;
}

public double getPt() {


return pt;
}

public static int getNro() {


return nro;
}

2.- La clase de Empleados.java (un arreglo para almacenar varios empleados)

Ing. Alberto Moreno


UTP -54-

package pack2;
import java.util.ArrayList;
import javax.swing.*;
public class Empleados {
private ArrayList emp;

public Empleados() {
emp=new ArrayList();

}
//para actualizar
public void update(Empleado e,int indice){
emp.set(indice,e);
}
//para adicionar nuevos empleados
public void AddEmp(Empleado e){
try{

emp.add(e);
}catch(Exception ex){
System.out.print("\n "+ex.getMessage());
}
}
//obtener un Empleado a partir de un indice
public Empleado GetEmp(int ind){
return (Empleado) emp.get(ind);
}
//obtener el tamaño del arraylist
public int Nroemp(){
return emp.size();
}
//busqueda por numero devolviendo su indice
public int Busca(int n){
for(int i=0;i<Nroemp();i++){
if(n==GetEmp(i).getNro()){
return i;
}

}
return -1;

//una sobrecarga Busqueda por Codigo, devolviendo su indice


public int Busca(String code){
for(int i=0;i<Nroemp();i++){
if(code.equals(GetEmp(i).getCode())){
return i;
}

Ing. Alberto Moreno


UTP -55-

}
return -1;

//quita un empleado a partir de un indice


public void Elimina(int nro){
emp.remove(nro);

}
//calcula el total pasando como dato un indice del arraylist
private double total(int f){
double tot;
if(this.GetEmp(f).getSec()=='A')
tot=this.GetEmp(f).getHoras()*13;
else
tot=this.GetEmp(f).getHoras()*15;
return tot;
}
//pasando un textArea va mostrar en dicho objeto la lista de datos
public void ListaArea(javax.swing.JTextArea xarea){
xarea.setText("Lista de Empleados \n");
xarea.append("\n Codigo \tNombre \t\tHoras\t Pago Total");
for(int f=0;f<Nroemp();f++){
xarea.append("\n"+ GetEmp(f).getCode()+
"\t"+GetEmp(f).getNome() +
"\t\t"+GetEmp(f).getHoras()+
"\t"+this.total(f));
}

}
//un listado simple mediante consola
public void Lista(){
//System.out.print("\nnro \t codigo \t nombre \t total");
for(int f=0;f<Nroemp();f++){
System.out.print("\n"+ this.GetEmp(f).getNro()+
"\t"+GetEmp(f).getCode()+
"\t"+GetEmp(f).getNome() +
"\t"+this.total(f));
}
} // fin del metodo

}fin de la clase

Ing. Alberto Moreno


UTP -56-

La ventana principal tipo Jdialog (EmpDialog.java)

package pruebas;
import pack1.prueba;
import pack2.*;
import javax.swing.JOptionPane;
public class EmpDialog extends javax.swing.JDialog {
static Empleados emp;
static Empleado uno;
/** Creates new form EmpDialog */

public EmpDialog(java.awt.Frame parent, boolean modal) {


super(parent, modal);
initComponents();
emp=new Empleados();
this.jRx.setVisible(false);
this.limpiar();
}
private void txthrKeyReleased(java.awt.event.KeyEvent evt) {
// TODO add your handling code here:
String dato=this.txthr.getText();
if(dato.trim().length()==0)
{ this.jbtAcepta.setEnabled(false);
return;
}
else{
try{
double p=Double.parseDouble(dato);
this.jbtAcepta.setEnabled(true);

}catch(Exception ex){
JOptionPane.showMessageDialog(this,"El dato debe ser numerico","error",
JOptionPane.ERROR_MESSAGE);

private void txtcodKeyReleased(java.awt.event.KeyEvent evt) {


// CUANDO SE INGRESA EL CODIGO
if(txtcod.getText().trim().length()==0){
this.jbtAcepta.setEnabled(false);
return;
}
else{
this.jbtAcepta.setEnabled(true);

Ing. Alberto Moreno


UTP -57-

private void JbtnModificaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
boolean flag=false;
String code,nom;
double horas;
code=this.txtcod.getText().trim();
int b=emp.Busca(code);
if(b==-1){
this.jTextArea1.setText("Codigo no existe");
return;
}
nom=emp.GetEmp(b).getNome();
horas=emp.GetEmp(b).getHoras();
pruebas.ModiEmpDialog ven=new
pruebas.ModiEmpDialog(null,true,code,nom,horas);
ven.setVisible(true);
if(ven.getFlag()==true){ //elimina el empleado
Empleado x=new Empleado();
x.setCode(code);
x.setHoras(ven.getHoras());
x.setNome(ven.getNom());
emp.update(x,b);
this.jTextArea1.setText("Registro actualizado");
}

private void JbeliminaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
boolean flag=false;
String code,nom;
double horas;
code=this.txtcod.getText().trim();
int b=emp.Busca(code);
if(b==-1){
this.jTextArea1.setText("Codigo no existe");
return;
}
nom=emp.GetEmp(b).getNome();
horas=emp.GetEmp(b).getHoras();
DelEmpDialog ven=new DelEmpDialog(null,true,code,nom,horas);
ven.setVisible(true);
if(ven.getFlag()==true){ //elimina el empleado
emp.Elimina(b);

Ing. Alberto Moreno


UTP -58-

this.jTextArea1.setText("Registro eliminado");
}

private void jbtnListaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
emp.ListaArea(this.jTextArea1);
}

private void jbtAceptaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
uno=new Empleado();
uno.setCode(this.txtcod.getText());
uno.setNome(this.txtnom.getText());
uno.setHoras(Double.parseDouble(this.txthr.getText()));
if(this.jRa.isSelected())
uno.setSec('A');
else
uno.setSec('B');
emp.AddEmp(uno);
JOptionPane.showMessageDialog(this,"Datos Aceptados");
limpiar();

void limpiar(){
this.txtcod.setText("");
this.txthr.setText("");
this.txtnom.setText("");
this.jRx.setSelected(true);//para deseleccionar las otras opciones
this.txtcod.requestFocus();

public static void main(String args[]) {


java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
new EmpDialog(new javax.swing.JFrame(), true).setVisible(true);
}
});
}

La ventana de Eliminación (DelEmpDialog.Java)

Ing. Alberto Moreno


UTP -59-

package pruebas;

/**
*
* @author utp
*/
public class DelEmpDialog extends javax.swing.JDialog {
private boolean flag=false;
/** Creates new form DelEmpDialog */
public DelEmpDialog(java.awt.Frame parent, boolean modal,
String nom, String cod, double ptot
){
super(parent, modal);
initComponents();
this.jLbcod.setText(cod);
this.jLbnom.setText(nom);
this.jLbtot.setText(""+ptot);

public boolean getFlag(){


return flag;
}
public void setFlag(boolean valor){
this.flag=valor;
}

private void jbtnAceptaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
this.flag=true;
this.setVisible(false);

Ventana de Dialogo para modificar los datos de un empleado:


package pruebas;

/**
*
* @author utp
*/
public class ModiEmpDialog extends javax.swing.JDialog {
private boolean flag=false;
private String nom;
private double horas;
/** Creates new form ModiEmpDialog */
public ModiEmpDialog(java.awt.Frame parent, boolean modal,
String cod,String nom, double hr
){
super(parent, modal);

Ing. Alberto Moreno


UTP -60-

initComponents();
this.jlbcod.setText(cod);
this.jlbnom.setText(nom);
this.jlbhoras.setText(""+hr);
this.jtxthoras.setText(""+hr);
this.jtxtnom.setText(nom);
}

public boolean getFlag(){


return flag;
}
public void setFlag(boolean f){
this.flag=f;
}
private void jbCancelaActionPerformed(java.awt.event.ActionEvent evt) {
// TODO add your handling code here:
this.setFlag(false);
this.setVisible(false);
}

private void jbtncambiaActionPerformed(java.awt.event.ActionEvent evt) {


// TODO add your handling code here:
this.setHoras(Double.parseDouble(this.jtxthoras.getText()));
this.setFlag(true);
this.setNom(this.jtxtnom.getText());
this.setVisible(false);

/**
* @param args the command line arguments
*/

public String getNom() {


return nom;
}

public void setNom(String nom) {


this.nom = nom;
}

public double getHoras() {


return horas;
}

public void setHoras(double horas) {


this.horas = horas;
}

Ing. Alberto Moreno


UTP -61-

Ing. Alberto Moreno


UTP -62-

CAPITULO DE HERENCIAS
La herencia permite crear una clase nueva (subclase o clase derivada) que tenga el
mismo comportamiento que otra (superclase o clase base) y además extienda o
adapte ese comportamiento
a unas necesidades específicas.
La nueva subclase heredará los atributos y los métodos de la clase base, los cuales se
añadirán a los definidos en la propia subclase.

La capacidad de descomponer un problema o concepto en un conjunto de


objetos relacionados entre sí, y cuyo comportamiento es fácilmente
identificable, puede ser muy útil para el desarrollo de programas informáticos.

B. Jerarquía

La herencia es el mecanismo fundamental de relación entre clases en la


orientación a objetos. Relaciona las clases de manera jerárquica; una clase
padre o superclase sobre otras clases hijas o subclases.

Imagen 4: Ejemplo de otro árbol de herencia

Los descendientes de una clase heredan todas las variables y métodos que
sus ascendientes hayan especificado como heredables, además de crear los
suyos propios.

La característica de herencia, nos permite definir nuevas clases derivadas de


otra ya existente, que la especializan de alguna manera. Así logramos definir
una jerarquía de clases, que se puede mostrar mediante un árbol de herencia.

C. Tipos de Herencia

En la orientación a objetos, se consideran dos tipos de herencia, simple y


múltiple. En el caso de la primera, una clase sólo puede derivar de una única
superclase. Para el segundo tipo, una clase puede descender de varias
superclases.

D. Declaración

Para indicar que una clase deriva de otra, heredando sus propiedades
(métodos y atributos), se usa el término extends, como en el siguiente ejemplo:

public class SubClase extends SuperClase {

// Contenido de la clase

Ing. Alberto Moreno


UTP -63-

Por ejemplo, creamos una clase Persona

public class Persona {


String nombre;
int edad;
String domicilio;
public Persona() {
}
void asignarEdad(int ed){
this.edad=ed;
}
void asignarNombre(String nom){
nombre=nom;
}
int obtenerEdad(){
return edad;
}
String obtenerNombre(){
return nombre;
}
}

Luego creamos una subclase llamada Alumno

public class Alumno extends Persona{


int semestre;
String seccion;
public Alumno() {
}

void asignarSemestre(int semes){


semestre=semes;
}
void asignarSeccion(String sec){
seccion=sec;
}
int obtenerSemestre(){
return semestre;
}

String obtenerSeccion(){
return grupo;
}
}

La palabra clave extends se utiliza para decir que deseamos crear una
subclase de la clase que es nombrada a continuación, en nuestro caso Alumno
es hija de Persona.

Ing. Alberto Moreno


UTP -64-

E. Limitaciones en la herencia

Todos los campos y métodos de una clase son siempre accesibles para el
código de la misma clase.

Sin embargo los tres primeros modificadores (public, private y protected) son
los más comunes que se usan para controlar el acceso desde otras clases, y
para controlar la herencia por las subclases.

public: Los miembros declarados public son accesibles en cualquier lugar en


que sea accesible la clase, y son heredados por las subclases.

• private: Los miembros declarados private son accesibles sólo en la


propia clase.
• protected: Los miembros declarados protected son accesibles sólo para
sus subclases

Por ejemplo veamos otra clase:

class Padre { // Hereda de Object


// Atributos
private int numeroFavorito, nacidoHace, dineroDisponible;
// Métodos
public int getApuesta() {
return numeroFavorito;
}
protected int getEdad() {
return nacidoHace;
}
private int getSaldo() {
return dineroDisponible;
}
}
class Hija extends Padre {
// Definición
}
class Visita {
// Definición
}

En este ejemplo, un objeto de la clase Hija, hereda los tres atributos


(numeroFavorito, nacidoHace y dineroDisponible) y los tres métodos (
getApuesta(), getEdad() y getSaldo() ) de la clase Padre, y podrá invocarlos.
Cuando se llame al método getEdad() de un objeto de la clase Hija, se
devolverá el valor de la variable de instancia nacidoHace de ese objeto, y no de
uno de la clase Padre.

Sin embargo, un objeto de la clase Hija, no podrá invocar al método getSaldo()


de un objeto de la clase Padre, con lo que se evita que el Hijo conozca el
estado de la cuenta corriente de un Padre.

Ing. Alberto Moreno


UTP -65-

La clase Visita, solo podrá acceder al método getApuesta(), para averiguar el


número favorito de un Padre, pero de ninguna manera podrá conocer ni su
saldo, ni su edad

Las clases no pueden declararse ni protected , ni private .

F. COMPOSICIÓN

La técnica en la que una clase se compone o contiene instancias de otras


clases se denomina composición. Es una técnica muy habitual cuando se
diseñan clases.

Por ejemplo analicemos el sig. código:

class Circulo {
Punto centro;
int radio;
float superficie() {
return 3.14 * radio * radio;
}
}

Diríamos que un Circulo tiene un Punto (centro) y un radio.

G. REDEFINICIÓN DE MÉTODOS. EL USO DE super.

Analicemos el siguiente ejemplo:

class Empleado {
String nombre;
int numEmpleado , sueldo;

static private int contador = 0;

Empleado(String nombre, int sueldo) {


this.nombre = nombre;
this.sueldo = sueldo;
numEmpleado = ++contador;
}

public void aumentarSueldo(int porcentaje) {


sueldo += (int)(sueldo * aumento / 100);
}

Ing. Alberto Moreno


UTP -66-

public String toString() {


return "Num. empleado " + numEmpleado + "
Nombre: " + nombre +
" Sueldo: " + sueldo;
}
}

En el ejemplo el Empleado se caracteriza por un nombre (String) y por un


número de empleado y sueldo (enteros). La clase define un constructor que
asigna los valores de nombre y sueldo y calcula el número de empleado a partir
de un contador (variable estática que siempre irá aumentando), y dos métodos,
uno para calcular el nuevo sueldo cuando se produce un aumento de sueldo
(método aumentarSueldo) y un segundo que devuelve una representación de
los datos del empleado en un String.(método toString).
Con esta representación podemos pensar en otra clase que reúna todas las
características de Empleado y añada alguna propia. Por ejemplo, la clase
Ejecutivo. A los objetos de esta clase se les podría aplicar todos los datos y
métodos de la clase Empleado y añadir algunos, como por ejemplo el hecho de
que un Ejecutivo tiene un presupuesto.
Así diríamos que la clase Ejecutivo extiende o hereda la clase Empleado. Esto
en Java se hace con la cláusula extends que se incorpora en la definición de la
clase, de la siguiente forma:

class Ejecutivo extends Empleado {


int presupuesto;
void asignarPresupuesto(int p) {
presupuesto = p;
}
}

Con esta definición un Ejecutivo es un Empleado que además tiene algún


rasgo distintivo propio. El cuerpo de la clase Ejecutivo incorpora sólo los
miembros que son específicos de esta clase, pero implícitamente tiene todo lo
que tiene la clase Empleado.
A Empleado se le llama clase base o superclase y a Ejecutivo clase derivada o
subclase.
Los objetos de las clases derivadas se crean igual que los de la clase base y
pueden acceder tanto sus datos y métodos como a los de la clase base. Por
ejemplo:

Ejecutivo jefe = new Ejecutivo( "Armando Mucho",


1000);
jefe.asignarPresupuesto(1500);
jefe.aumentarSueldo(5);

Atención!: Un Ejecutivo ES un Empleado, pero lo contrario no es cierto. Si


escribimos:

Ing. Alberto Moreno


UTP -67-

Empleado curri = new Empleado ( "Esteban Comex


Plota" , 100) ;
curri.asignarPresupuesto(5000); // error

se producirá un error de compilación pues en la clase Empleado no existe


ningún método llamado asignarPresupuesto.

Ahora bien veamos como podemos redefinir un método

Se podría pensar en redefinir algunos métodos de la clase base pero haciendo


que métodos con el mismo nombre y características se comporten de forma
distinta. Por ejemplo podríamos pensar en rediseñar el método toString de la
clase Empleado añadiendo las características propias de la clase Ejecutivo. Así
se podría poner:

class Ejecutivo extends Empleado {


int presupuesto;

void asignarPresupuesto(int p) {
presupuesto = p;
}

public String toString() {


String s = super.toString();
s = s + " Presupuesto: " + presupuesto;
return s;
}
}

De esta forma cuando se invoque jefe.toString() se usará el método toString de


la clase Ejecutivo en lugar del existente en la clase Empleado.

Observe en el ejemplo el uso de super, que representa referencia interna


implícita a la clase base (superclase). Mediante super.toString() se invoca el
método toString de la clase Empleado

Continuando con el uso de super e inicialización de clases derivadas

Cuando se crea un objeto de una clase derivada se crea implícitamente un


objeto de la clase base que se inicializa con su constructor correspondiente. Si
en la creación del objeto se usa el constructor no-args, entonces se produce
una llamada implícita al constructor no-args para la clase base. Pero si se usan
otros constructores es necesario invocarlos explicitamente.

En nuestro ejemplo dado que la clase método define un constructor,


necesitaremos también un constructor para la clase Ejecutivo, que podemos
completar así:

class Ejecutivo extends Empleado {


int presupuesto;

Ing. Alberto Moreno


UTP -68-

Ejecutivo (String n, int s) {


super(n,s);
}

void asignarPresupuesto(int p) {
presupuesto = p;
}

public String toString() {


String s = super.toString();
s = s + " Presupuesto: " + presupuesto;
return s;
}
}

Observe que el constructor de Ejecutivo invoca directamente al constructor de


Empleado mediante super(argumentos). En caso de resultar necesaria la
invocación al constructor de la superclase debe ser la primera sentencia del
constructor de la subclase.

Ejemplo 2.- Elaborar la clase documento que sera heredado por la clase
Factura y la clase boleta:
Documento
String numero
String fecha
Double monto

Factura Boleta
String ruc String Nombre

import javax.swing.JOptionPane;
import java.util.ArrayList;
public class GestorVentas {
public static ArrayList ListaD=new ArrayList();
public static void main(String[] args) {
int op;
String Menu="(0)Salir\n" +
"(1)Nueva Factura\n" +
"(2)Nueva Boleta\n" +
"(3)LIstar Todos\n" +
"(4)Listar Facturas\n" +
"(5)Listar Boletas\n" +
"(6)Buscar Facturas\n" +
"(7)Calcular Igv\n";
for(;;){

Ing. Alberto Moreno


UTP -69-

op=Integer.parseInt(JOptionPane.showInputDialog(Menu));
switch(op){
case 0: System.exit(0);break;
case 1: nuevaFactura();break;
case 2: nuevaBoleta();break;
case 3: listarTodos();break;
case 4: listarFacturas();break;
case 5: lsitarBoletas();break;
case 6: buscarfatura(num);break;
case 7: calcularIgv();break;
default: JOptionPane.showMessageDialog(null,"Opcion Incorrecta");
} //fin del switch
}//del for
} //del main

public static void nuevaFatura(){


Factura F=new Factura();
F.Fecha=JOptionPane.showInputDialog("Ingrese la Fecha");
F.Monto=Double.parseDouble(JOptionPane.showInputDialog("Ingrese el
Monto"));
F.Numero=Integer.parseInt(JOptionPane.showInputDialog("Ingrese el Numero"));
F.Ruc=Integer.parseInt(JOptionPane.showInputDialog("Ingrese el Ruc"));
ListaD.add(F);
}
public static void nuevaBoleta(){
Boleta B=new Boleta();
B.Fecha=JOptionPane.showInputDialog("Ingrese la Fecha");
B.Monto=Double.parseDouble(JOptionPane.showInputDialog("Ingrese el
Monto"));
B.Numero=Integer.parseInt(JOptionPane.showInputDialog("Ingrese el
Numero"));
B.Nombre=JOptionPane.showInputDialog("Ingrese el Nombre");
ListaD.add(B);
}
public static void listarTodos(){
for(int i=0;i<ListaD.size();i++){
if(ListaD.get(i) instanceof Factura){
((Factura)ListaD.get(i)).imprimir();
}else{
((Boleta)ListaD.get(i)).imprimir();
}
}
}
public static void listarFacturas(){
for(int i=0;i<ListaD.size();i++){
if(ListaD.get(i)instanceof Factura) {
((Factura)ListaD.get(i)).imprimir();
}
}

Ing. Alberto Moreno


UTP -70-

}
public static void listarBoletas(){
for(int i=0;i<ListaD.size();i++){
if(ListaD.get(i) instanceof Boleta){
((Boleta)ListaD.get(i)).imprimir();
}
}
}
public static void buscarfatura(int num){
int num;
num=Integer.parseInt(JOptionPane.showInputDialog("Ingrese el numero"));
for(int i=0;i<ListaD.size();i++){
if(ListaD.get(i) instanceof Factura){
if(((Factura)ListaD.get(i)).Numero==num){
((Factura)ListaD.get(i)).imprimir();
}
}
}
}
public static void calcularIgv(){
for(int i=0;i<ListaD.size();i++){
if(ListaD.get(i) instanceof Factura){
((Factura)ListaD.get(i)).imprimir();
double igv;
double monto=((Factura)ListaD.get(i)).Monto;
igv= monto-(monto/1.19);
System.out.println("Su Igv es ......"+igv);
}
}
}
}
//fin de la clase principal gestor de Ventas
class Documento{
String Fecha;
double Monto;
int Numero;
void imprimir(){
System.out.println("Fecha :"+Fecha);
System.out.println("Monto :"+Monto);
System.out.println("Numero:"+Numero);
}
}
//
class Boleta extends Documento{
String Nombre;
void imprimir(){
System.out.println("Nombre :"+Nombre);
}
}
//

Ing. Alberto Moreno


UTP -71-

class Factura extends Documento{


int Ruc;
void imprimir(){
super.imprimir();
System.out.println("Ruc :"+Ruc);
}
}

Ejercicios:

1Crear una clase animal (nombre, nro de patas, sexo) crear las subclases Perro (atributo
raza, atributo habla), gallo( metodo canta), Gato(metodo maulla)

2.- crear la clase TarjetaCredito( nro de tarjeta, nombre del cliente, fecha de caducacion)
crear las subclases TarjetaDorada(linea de credito, Cargo ), TarjetaTotus(sueldo del
cliente, Empresa donde trabaja) realizar las subclases ademas comprobarlo en el main
para asignar los datos.

3.- (Sistema de Nómina) Elaborar un programa que permita procesar la nómina de una
empresa.
Para ello considere el siguiente diagrama de clases:

Ing. Alberto Moreno


UTP -72-

Un empleado (Empleado=Employee) debe tener un primer nombre, apellido paterno y


número de seguro social. Además, un EmpleadoAsalariado (SalariedEmployee) debe
tener un salario semanal; un EmpleadoPorHoras (HourlyEmployee) debe tener un
sueldo y el número de horas trabajadas; un EmpleadoPorComision
(CommissionEmployee) debe tener una tasa por comisiones y ventas brutas; y un
EmpleadoBaseMasComision (BasePlusCommissionEmployee) debe tener un salario
base. Cada clase debe tener las construcciones apropiadas, los métodos relevantes sets y
gets. Escriba un programa que cree instancias de objetos de cada una de las clases, y
que muestre toda la información asociada con cada objeto (incluyendo la información
heredada).

Interfaz Gráfica de Usuario (GUI)

Ing. Alberto Moreno


UTP -73-

EJEMPLOS DE HERENCIA
Crear una clase circulo cuyo atributo
import java.text.DecimalFormat; es el radio y los métodos a crear son
public class herencia01 { Area() y Print() para el calculo del
area del circulo e impresión
public static void main(String[] args) { respectiva de los datos.
// TODO code application logic here Crear la clase Cilindro cuyo atributo
circulo x=new circulo(); son :radio y altura hacer la herencia
x.setRadio(5); correspondiente para el calculo de su
x.imprime(); área y volumen del cilindro.
Cilindro y=new Cilindro();
y.setRadio(7);
y.altura=12;
y.imprime();

}
//LA CLASE PRINCIPAL CIRCULO
class circulo{
private int radio;
DecimalFormat dos=new DecimalFormat("0.00");

double area(){
return radio*radio*Math.PI;
}
void imprime(){
System.out.print("\n area del circulo "+dos.format(area()));
}

public int getRadio() { //ENCAPSULA EL DATO PARA LEER


return radio;
}

public void setRadio(int radio) { // PARA ESCRIBIR


this.radio = radio;
}

}
class Cilindro extends circulo{ //CLASE EXTENDIDA DE LA CLASE CIRCULO
int altura;
double area(){
double ac;
ac=super.area()*altura;

return ac;
}
void imprime(){
super.imprime();

Ing. Alberto Moreno


UTP -74-

System.out.print("\n area del cilindro:"+dos.format(area()));


}
}

Poliformismo.- un método puede comportarse de muchas formas de acuerdo a la clase


donde se emplea dicho método , por ejemplo el calculo del promedio depende de la
clase si es pregrado el calculo del promedio es :(n1*0.25+ n2*0.25 +0.50*n3) y para
PostGrado =(n1+n2+n3)/3

Postgrado
Alumno
public Alumno()
public Imprime()
public abstract Promedio()
package herencia;
Pregrado
Clase Alumno.java //herencia de la clase alumno
public class AlumnoPostgrado extends
package herencia; Alumno {
abstract class Alumno {
private String matricula; public AlumnoPostgrado(String nom,
private String nombre; String mat,
protected double n1, n2, n3; double n1, double n2, double n3)
//constructor de la clase alumno {
public Alumno(String mat, String n, super(mat,nom,n1,n2,n3);
double n1, double n2, double n3) { }
matricula = mat;
nombre = n; public double calcularNota() {
this.n1 = n1; return (n1+n2+n3)/3.0;
this.n2 = n2; }
this.n3 = n3; }
}
public void Imprime(){
System.out.print("\n Matricula:"+this.matricula);
System.out.print("\n Nombre:"+this.nombre);
System.out.print("\n nota1:"+this.n1);
System.out.print("\n nota2:"+this.n2);
System.out.print("\n nota3:"+this.n3);

}
// metodo abstracto para el polimorfismo
abstract double calcularNota();

Ing. Alberto Moreno


UTP -75-

package herencia;

public class AlumnoPregrado extends Alumno {

/** Creates a new instance of AlumnoPregrado */


public AlumnoPregrado(String nom, String mat,
double n1, double n2, double n3) {
super(mat,nom,n1,n2,n3);
}

public double calcularNota() {


return n1*0.25 + n2*0.25 + n3*0.5;
}
}

Comprobación de las clases

package herencia;

import java.util.*;

public class prueba1 {

public static void main(String[] args) {


ArrayList x = new ArrayList();
AlumnoPregrado apre;
AlumnoPostgrado apos;
Alumno a;
apre = new AlumnoPregrado("Laura","1",5,6,4);
x.add(apre);
apre = new AlumnoPregrado("Claudia","2",4,7,7);
x.add(apre);
apos = new AlumnoPostgrado("Juan","3",5,6,4);
x.add(apos);
apos = new AlumnoPostgrado("Ana","4",4,7,7);
x.add(apos);

// Calculo de notas SIN polimorfismo


for (int i=0; i<x.size(); i++) {
if (x.get(i) instanceof AlumnoPregrado) {

Ing. Alberto Moreno


UTP -76-

apre = (AlumnoPregrado)x.get(i);
apre.Imprime();

System.out.println("\n promedio:"+apre.calcularNota());
}
else {
apos = (AlumnoPostgrado)x.get(i);
System.out.println(apos.calcularNota());
}
}

// Calculo de notas aprovechando el polimorfismo


System.out.print("\n impresion 2");

for (int i=0; i<x.size(); i++) {


a = (Alumno)x.get(i);
a.Imprime();

System.out.println("\n promedio:"+a.calcularNota());
}
}

Gestión de Excepciones
Las excepciones son el mecanismo por el cual pueden controlarse en un programa Java
las condiciones de error que se producen. Estas condiciones de error pueden ser errores
en la lógica del programa como un índice de un array fuera de su rango, una división
por cero o errores disparados por los propios objetos que denuncian algún tipo de estado
no previsto, o condición que no pueden manejar.

La idea general es que cuando un objeto encuentra una condición que no sabe manejar
crea y dispara una excepción que deberá ser capturada por el que le llamó o por alguien
más arriba en la pila de llamadas. Las excepciones son objetos que contienen
información del error que se ha producido y que heredan de la clase Throwable o de la
clase Exception. Si nadie captura la excepción interviene un manejador por defecto que
normalmente imprime información que ayuda a encontrar quién produjo la excepción.

Existen dos categorías de excepciones:

• Excepciones verificadas: El compilador obliga a verificarlas. Son todas las que


son lanzadas explicitamente por objetos de usuario.
• Excepciones no verificadas: El compilador no obliga a su verificación. Son
excepciones como divisiones por cero, excepciones de puntero nulo, o índices
fuera de rango.

Ing. Alberto Moreno


UTP -77-

Generación de excepciones

Supongamos que tenemos una clase Empresa que tiene un array de objetos Empleado
(clase vista en capítulos anteriores). En esta clase podríamos tener métodos para
contratar un Empleado (añadir un nuevo objeto al array), despedirlo (quilarlo del array)
u obtener el nombre a partir del número de empleado. La clase podría ser algo así como
lo siguiente:

public class Empresa {


String nombre;
Empleado [] listaEmpleados;
int totalEmpleados = 0;
. . .
Empresa(String n, int maxEmp) {
nombre = n;
listaEmpleados = new Empleado [maxEmp];
}
. . .
void nuevoEmpleado(String nombre, int sueldo) {
if (totalEmpleados < listaEmpleados.length ) {
listaEmpleados[totalEmpleados++] = new Empleado(nombre,sueldo);
}
}
}

Observese en el método nuevoEmpleado que se comprueba que hay sitio en el array


para almacenar la referencia al nuevo empleado. Si lo hay se crea el objeto. Pero si no lo
hay el método no hace nada más. No da ninguna indicación de si la operación ha tenido
éxito o no. Se podría hacer una modificación para que, por ejemplo el método
devolviera un valor booleano true si la operación se ha completado con éxito y false si
ha habido algún problema.

Otra posibilidad es generar una excepción verificada (Una excepción no verificada se


produciría si no se comprobara si el nuevo empleado va a caber o no en el array).
Vamos a ver como se haría esto.

Las excepciones son clases, que heredan de la clase genérica Exception. Es necesario
por tanto asignar un nombre a nuestra excepción. Se suelen asignar nombres que den
alguna idea del tipo de error que controlan. En nuestro ejemplo le vamos a llamar
CapacidadEmpresaExcedida.

Para que un método lance una excepción:

• Debe declarar el tipo de excepción que lanza con la cláusula throws, en su


declaración.
• Debe lanzar la excepción, en el punto del código adecuado con la sentencia
throw.

En nuestro ejemplo:

void nuevoEmpleado(String nombre, int sueldo) throws


CapacidadEmpresaExcedida {
if (totalEmpleados < listaEmpleados.length) {

Ing. Alberto Moreno


UTP -78-

listaEmpleados[totalEmpleados++] = new Empleado(nombre,sueldo);


}
else throw new CapacidadEmpresaExcedida(nombre);
}

Además, necesitamos escribir la clase CapacidadEmpresaExcedida. Sería algo


así:

public class CapacidadEmpresaExcedida extends Exception {


CapacidadEmpresaExcedida(String nombre) {
super("No es posible añadir el empleado " + nombre);
}
. . .
}

La sentencia throw crea un objeto de la clase CapacidadEmpresaExcedida . El


constructor tiene un argumento (el nombre del empleado). El constructor simplemente
llama al constructor de la superclase pasándole como argumento un texto explicativo del
error ( y el nombre del empleado que no se ha podido añadir).

La clase de la excepción puede declarar otros métodos o guardar datos de depuración


que se consideren oportunos. El único requisito es que extienda la clase Exception.
Consultar la documentación del API para ver una descripción completa de la clase
Exception.

De esta forma se pueden construir métodos que generen excepciones.

Captura de excepciones

Con la primera versión del método nuevoEmpleado (sin excepción) se invocaría este
método de la siguiente forma:

Empresa em = new Empresa("La Mundial");


em.nuevoEmpleado("Adán Primero",500);

Si se utilizara este formato en el segundo caso (con excepción) el compilador produciría


un error indicando que no se ha capturado la excepción verificada lanzada por el método
nuevoEmpleado. Para capturar la excepción es utiliza la construcción try / catch, de la
siguiente forma:

Empresa em = new Empresa("La Mundial");


try {
em.nuevoEmpleado("Adán Primero",500);
} catch (CapacidadEmpresaExcedida exc) {
System.out.println(exc.toString());
System.exit(1);
}

• Se encierra el código que puede lanzar la excepción en un bloque try / catch.


• A continuación del catch se indica que tipo de excepción se va a capturar.
• Después del catch se escribe el código que se ejecutará si se lanza la excepción.
• Si no se lanza la excepción el bloque catch no se ejecuta.

Ing. Alberto Moreno


UTP -79-

El formato general del bloque try / catch es:

try {
. . .
} catch (Clase_Excepcion nombre) { . . .}
catch (Clase_Excepcion nombre) { . . .}
. . .

Observese que se puede capturar más de un tipo de excepción declarando más de una
sentencia catch. También se puede capturar una excepción genérica (clase Exception)
que engloba a todas las demás.

Supongamos que, en nuestro ejemplo es el método main de una clase el que invoca el
método nuevoEmpleado. Si no quiere capturar la excepción debe hacer lo siguiente:

public static void main(String [] args) throws


CapacidadEmpresaExcedida {
Empresa em = new Empresa("La Mundial");
em.nuevoEmpleado("Adán Primero",500);
}

Cláusula finally

La cláusula finally forma parte del bloque try / catch y sirve para especificar
un bloque de código que se ejecutará tanto si se lanza la excepción como si no. Puede
servir para limpieza del estado interno de los objetos afectados o para liberar recursos
externos (descriptores de fichero, por ejemplo). La sintaxis global del bloque try /
catch / finally es:

try {
. . .
} catch (Clase_Excepcion nombre) {...}
catch (Clase_Excepcion nombre) {...}
. . .
finally {...}

Ing. Alberto Moreno


UTP -80-

Links de interés para el curso


tema link
Características del java http://www.webtaller.com/manual-
java/caracteristicas-java.php
Conceptos básicos http://www.webtaller.com/manual-
java/programacion.php
Control de flujo http://www.webtaller.com/manual-java/control-
flujo.php
Introducción a variables y http://www.webtaller.com/manual-java/variables-
métodos metodos.php
Presentación, introducción, http://www.monografias.com/trabajos42/manual-
cadenas de caracteres, sentencias de-java/manual-de-java.shtml
de control, arreglos, clases y
herencia
Funciones matemáticas, uso de http://www.cec.uchile.cl/manuales/contenidos/Java/
String, Uso de StringBuffers

Ing. Alberto Moreno