Imprimir un parámetro de un método

Iniciado por Aikanáro Anário, 14 Septiembre 2011, 08:21 AM

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

Aikanáro Anário

Esta es mi clase principal:
Código (java) [Seleccionar]
public class Practica5c {

public class Practica5c {
public static void main (String args[]){
Coche coche1 = new Coche("Toyota", "Camry");
Coche coche2 = new Coche("Honda", "Accord");
Garaje garaje = new Garaje();

garaje.aceptarCoche(coche1, "goma pichada");
garaje.devolverCoche();

garaje.aceptarCoche(coche2, "aceite");
garaje.devolverCoche();

System.out.println("El coche 1 es: "+ coche1.getMarca() +" "+ coche1.getModelo() +"\n La averia es "+ garaje.getAveria() +"\n El precio en averias es "+ coche1.getImporteAveria());
System.out.println("El coche 2 es: "+ coche2.getMarca() +" "+ coche2.getModelo() +"\n La averia es "+ garaje.getAveria() +"\n El precio en averias es "+ coche2.getImporteAveria());
}
}
}


Pero cuando se imprime la avería y el precio en averías son iguales.

La clase Garaje es esta:
Código (java) [Seleccionar]

public class Garaje{
//atributos
private Coche coche;
private String averia;
private int nCochesAtendidos;
private boolean cocheAdentro;

//constructor PUEDE QUE NO VAYA
public Garaje(){
}



//metodo Aceptar Coche
public boolean aceptarCoche(Coche param1, String dano){
averia = dano;
nCochesAtendidos += 1;
if(cocheAdentro == true){
System.out.println("Ya hay un coche en el garage");
return false;
}
else{
cocheAdentro = true;
if(averia == "aceite"){
Motor motor = new Motor(10);
Motor.setLtAceite(10);
Coche.acumularAveria(Math.random()*1000);
}
return true;
}
}

//metodo obtener averia
public String getAveria(){
return averia;
}

//metodo devolverCoche
public void devolverCoche(){
cocheAdentro = false;
}
}


Tal vez haya hecho mucho disparates porque todavía no entiendo bien la orientación a objetos, pero ahora mismo lo que más  me interesa es saber como puedo hacer que se imprima la correspondiente avería para cada uno de los carros y lo mismo con el precio de averias. Creo que si puediera imprimir el parámetro del método aceptarCoche lo podría hacer para la avería.

Es una versión simplificada de esta práctica
Lo que faltaba en internet: http://binar10s.blogspot.com/

Valkyr

Vamos a ir por partes para ver si consigo expresarme correctamente.

En primer lugar deberías haber colgado el método acumularAvería de la clase coche, ya que es ahí donde puede ser que tengas el problema.

Por otro lado, en la clase Garaje, más concretamente en el método aceptarCoche haces esto:

Código (java) [Seleccionar]

public boolean aceptarCoche(Coche param1, String dano){
averia = dano;
nCochesAtendidos += 1;
if(cocheAdentro == true){
System.out.println("Ya hay un coche en el garage");
return false;
}
else{
cocheAdentro = true;
if(averia == "aceite"){
Motor motor = new Motor(10);
Motor.setLtAceite(10);
Coche.acumularAveria(Math.random()*1000);
}
return true;
}
}

En primer lugar deberías comprobar al mismo entrar la condición de que no haya ningún coche dentro, porque si se da el caso de que hay uno dentro el método va a devolver false sí, pero has cambiado los valores de avería y nCochesAtendidos cuando eso no debería pasar ya que el coche no se va a quedar dentro.

También en esa clase tienes un atributo de tipo Coche que no usas para nada.

En el método Main me imagino que a la hora de imprimir por pantalla el tipo de avería te mostrará la misma, eso es por que estás mostrando la información cuando ya han pasado los dos coches. Tendrías que mostrarla en cuanto salga del garaje y antes de que entre otro coche, porque si no la información de la avería se pierde, no se si me explico correctamente.

Postea el método acumularAveria y getImporteAveria y te podremos ayudar con eso.

Saludos y no te preocupes, al empezar siempre cuesta un poco, pero luego la cosa sale sola ;)

Aikanáro Anário

#2
CitarEn el método Main me imagino que a la hora de imprimir por pantalla el tipo de avería te mostrará la misma, eso es por que estás mostrando la información cuando ya han pasado los dos coches. Tendrías que mostrarla en cuanto salga del garaje y antes de que entre otro coche, porque si no la información de la avería se pierde, no se si me explico correctamente.

Tienes razón, ese era parte del problema. La otra parte es que
Código (java) [Seleccionar]
Coche.acumularAveria(Math.random()*1000); estaba dentro del if y esa sentencia debe ejecutarse tanto si la averia es aceite como si es cualquier otra.

Ahora el main me quedo así:
Código (java) [Seleccionar]
public class Practica5c {
public static void main (String args[]){
Coche coche1 = new Coche("Toyota", "Camry");
Coche coche2 = new Coche("Honda", "Accord");
Garaje garaje = new Garaje();
Motor motor = new Motor(0);

int i;
for(i=0;i<2;i++){
System.out.print("\n\nEl coche 1 es: "+ coche1.getMarca() +" "+ coche1.getModelo() +"\nLa averia es ");
garaje.aceptarCoche(coche1, "goma pichada");
System.out.print(garaje.getAveria()+ "\nEl precio por averia es " +coche1.getImporteAveria()+ "\nLt de aceite: " +motor.getLtAceite());
garaje.devolverCoche();

System.out.print("\n\nEl coche 2 es: "+ coche2.getMarca() +" "+ coche2.getModelo() +"\nLa averia es ");
garaje.aceptarCoche(coche2, "aceite");
System.out.print(garaje.getAveria() +"\nEl precio por averia es "+coche2.getImporteAveria()+ "\nLt de aceite: " +motor.getLtAceite());
garaje.devolverCoche();
}

System.out.println("\n\nCoches atendidos: "+garaje.getAtendidos());
}
}


Ahora está un poquito más "limpio" porque antes tenía un print en el método aceptarCoche(...) que me daba la avería. Eso fue lo que hice porque cuando accedía a getAveria salía la misma.

Métodos acumularAveria y getImporteAveria
Código (java) [Seleccionar]
public static void acumularAveria(double param1){
importeAveria += param1;
}

public double getImporteAveria(){
return importeAveria;
}

Lo que faltaba en internet: http://binar10s.blogspot.com/

Valkyr

El problema está aquí:

Código (java) [Seleccionar]
public boolean aceptarCoche(Coche param1, String dano){
averia = dano;
nCochesAtendidos += 1;
if(cocheAdentro == true){
System.out.println("Ya hay un coche en el garage");
return false;
}
else{
cocheAdentro = true;
if(averia == "aceite"){
Motor motor = new Motor(10);
Motor.setLtAceite(10);
Coche.acumularAveria(Math.random()*1000);
}
return true;
}
}


La variable de tipo Coche no la inicializas a ningún valor así que al hacer la llamada no la hace sobre el objeto que tú le pasas como parámetro a la función. ¿Cómo solucionarlo? Cuando un coche entra al garaje (después de comprobar que esté vacío) le asigna a la variable "coche" el primer parámetro de la función, es decir:

Código (java) [Seleccionar]

public boolean aceptarCoche(Coche param1, String dano){
                if(cocheAdentro == true){
System.out.println("Ya hay un coche en el garage");
return false;
}
                coche = param1;
averia = dano;
nCochesAtendidos += 1;
else{
cocheAdentro = true;
if(averia == "aceite"){
Motor motor = new Motor(10);
Motor.setLtAceite(10);
Coche.acumularAveria(Math.random()*1000);
}
return true;
}
}


De esta forma podrías llamar al método acumularAvería y no necesitarías que fuese Static.

Saludos, cualquier duda pregunta ;).

Aikanáro Anário

Ohh, ya. Si no hubiera estado programando con un IDE (Eclipse) es seguro que el programa no me hubiera corrido o lo hubiera hecho mal.

Por que el compilador me dió la solución de que esa clase debía ser static, pero no sabía porque, simplemente apliqué la sugerencia.
Lo que faltaba en internet: http://binar10s.blogspot.com/

Valkyr

Hay que saber que el IDE te recorta mucho la tarea y te ayuda muchísimas veces, pero no es una persona y no hay que fiarse de todo lo que diga. Ese error es normal, sobre todo si estás empezando a programar ahora con Java. Con un poco de práctica y equivocandote de vez en cuando seguro que consigues muy buenas cosas.

Saludos.