Ingenieria de Software en le Manejo de Errores

Iniciado por cyberserver, 24 Diciembre 2010, 01:07 AM

0 Miembros y 1 Visitante están viendo este tema.

cyberserver

Hola amigos.

Quisiera abrir una pregunta acerca del manejor de errores teniendo ingenieria de software.!

La pregunta es quiza muy tonta pero me gustaria saber cual es la mejor manera para Avisar al Usuario de un error sin comprometer el Resultado Devuelto por el metodo o agregando mensajes ENORMES que quiten una bonita interface Y/o estetica de la aplicacion.

Por ejemplo en el siguiente metodo de Java, como podria avisar de un Error sin tener que colocar un Mensaje enorme que diga del error.

public int Suma(int a,int b){
     try{
        return a+b;
     }catch(Exception Error){
       JOptionPane.showMessengerDialog(null,"El error es " + Error);
       return null;
     }
}


Pensando en Java:
Esto del manejo de errores y la mejor forma para tratarlos no lo hago solo por estetica.! si no por buen funcionamiento de la aplicacion. ya que si queremos exportar una Clase a nivel web (JSP) no es funcional JOptionPane. y no quiero comprometer el resultado devuelto por el metodo por mostrar un tipo de Error.

como podria avisar de un Error sin usar un Mensage?






leogtz

Yo creo que depende del programador y de la importancia del dato. Yo no lo dejaría proceder hasta que de una respuesta buena. Por otra parte, yo recomendaría darle el mensaje en un JLabel en rojo en vez de un JOption....  >:D
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

1mpuls0

#2
Has intentado con

Código (java) [Seleccionar]

try {
        ...
}
catch(Exception Error) {
       JOptionPane.showMessengerDialog(null,Error.getMessage());
}


Además no lo estas hacienco como se deve (lo digo por tú código Java) ya que debes utilizar POO.

Por lo menos yo, intentaría manejar las Excepciones aparte.

Por ejemplo.

Código (java) [Seleccionar]

import javax.swing.JOptionPane;

public class Suma {

private int resultado;

public static void main(String args[]) {
new Suma();
}

public Suma() {
String a;
do{
a = JOptionPane.showInputDialog(null, "Escribe un numero entero", "Entrada", 1);
}while(!esNumero(a));

String b;
do {
b = JOptionPane.showInputDialog(null, "Escribe otro numero entero", "Entrada", 1);
}while(!esNumero(b));

int numeroA = Integer.parseInt(a);
int numeroB = Integer.parseInt(b);

int resultadoSuma = Sumar(numeroA, numeroB);

JOptionPane.showMessageDialog(null, "La suma de " +a +" y " +b +" es " + resultadoSuma, "Resultado", 1);

}

private boolean esNumero(String str) {
try {
Integer.parseInt(str);
return true;
}
catch(Exception e) {
JOptionPane.showMessageDialog(null, e.getMessage(), "Error", 0);
return false;
}
}

    private int Sumar(int numA, int numB) {
    return numA+numB;
    }
}


Estoy utiizando variables de más para explicarme un poco mejor.

La primera idea de Leo Gutiérrez no es mala pero tal vez si el usuario mira que la aplicación no hace nada, llegará a pensar que simplemente está bloqueada o algo por el estilo.
La segunda me parece buena  ;)

Un saludo.

EDITO.
Entonces por lo que entiendo intentas generalizar las excepciones?  :-\ si sabes que el usuario al intentar hacer una suma por que mostrar todo el String que te manda, si puedes hacer por ejemplo.

Código (java) [Seleccionar]

try {
...
}
catch(Exception e) {
JOptionPane.showMessageDialog(null, "Solo se aceptan valores numericos", "Error", 0);
}
abc