Vector de objetos

Iniciado por m@o_614, 13 Junio 2012, 21:39 PM

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

m@o_614

Saludos

estoy utilizando el API de Java para crear un vector de objetos tipo Gasto
Código (java) [Seleccionar]
class Gasto{
public String concepto;
public float monto;
public float iva;
public float total;
public Fecha mifecha;

public Gasto(String concepto,float monto,float iva,float total,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=iva;
this.total=total;
this.mifecha=mifecha;
}
}


pero en la clase ManejadorGastos en su método agregar sólo utiliza los atributos concepto,monto y fecha.

Código (java) [Seleccionar]
class ManejadorGastos{
private Gasto gasto=null;//agregacion
private Vector<Gasto> vector;

public ManejadorGastos(){
vector = new Vector<Gasto>();
}

public void agregarGasto(String concepto,float monto,Fecha fecha){
Gasto g;
g = new Gasto(concepto,monto,fecha);
vector.add(g);
}
}
pero en g=new Gasto me aparece un error, la clase Fecha ya la tengo implementada pero no la puse porque es muy larga

gracias

Valkyr

Te dará error porque el constructor Gasto(String, float, Fecha) no está definido, el que tu has puesto tiene dos parámetros más (iva y total).

m@o_614

#2
Saludos Valkyr

ya le agregue los atributos iva y total pero ahora me sale que iva y total cannot be resolved y no entiendo por qué

Código (java) [Seleccionar]
class Gasto{
public String concepto;
public float monto;
public float iva;
public float total;
public Fecha mifecha;

public Gasto(String concepto,float monto,float iva,float total,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=iva;
this.total=total;
this.mifecha=mifecha;
}
}

class ManejadorGastos{
private Gasto gasto=null;
private Vector<Gasto> vector;

public ManejadorGastos(){
vector = new Vector<Gasto>();
}

public void agregarGasto(String concepto,float monto,Fecha fecha){
Gasto g;
g = new Gasto(concepto,monto,iva,total,fecha);
vector.add(g);
}

en el método agregarGasto solo puede tener los parametros concepto, monto y fecha, así me lo exigieron
gracias

satu

Hola

Si el constructor tiene 5 parámetros al llamarlo tienes que pasarle 5 parámetros, pero éstos deben existir. En tu método agregarGasto le pasas los 5 pero iva y total no están declarados, los otros 3 los recibes por parámetro. Por lo tanto si solo puedes tener los parametros concepto, monto y fecha debes crearte otro constructor con 3 parámatros así:

Código (java) [Seleccionar]

class Gasto{
public String concepto;
public float monto;
public float iva;
public float total;
public Fecha mifecha;

public Gasto(String concepto,float monto,float iva,float total,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=iva;
this.total=total;
this.mifecha=mifecha;
}

        public Gasto(String concepto, float monto, Fecha mifecha) {
this.concepto=concepto;
this.monto=monto;
                this.iva=0;
this.total=0;
this.mifecha=mifecha;
}
}

class ManejadorGastos{
private Gasto gasto=null;
private Vector<Gasto> vector;

public ManejadorGastos(){
vector = new Vector<Gasto>();
}

public void agregarGasto(String concepto,float monto,Fecha fecha){
Gasto g;
g = new Gasto(concepto,monto,fecha);
vector.add(g);
}


o también puedes tener el método así
Código (java) [Seleccionar]

public void agregarGasto(String concepto,float monto,Fecha fecha){
Gasto g;
                float iva = 0, total = 0;
g = new Gasto(concepto, iva, total, monto, fecha);
vector.add(g);
}


Saludos
Breakbeat como forma de vida

m@o_614

muchas gracias por tu respuesta satu ya hice las correcciones que me dijiste, ahora solo tengo una última duda, a la clase ManejadorGastos le tuve que implementar un método que me agregara un registro de gastos, otro método que al pasarle la posicion me devolviera el gasto qeu se encuentra en esa posicion y otro método para contar cuantos registro tengo, ya lo hice y no me marca errores pero quiero saber si esta hecho correctamente

Código (java) [Seleccionar]
class Gasto{
public String concepto;
public float monto;
public float iva;
public float total;
public Fecha mifecha;

public Gasto(String concepto,float monto,float iva,float total,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=iva;
this.total=total;
this.mifecha=mifecha;
}

public Gasto(String concepto,float monto,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=0;
this.total=0;
this.mifecha=mifecha;
}
}
class ManejadorGastos{
private Gasto gasto=null;
private Vector<Gasto> vector;

public ManejadorGastos(){
vector = new Vector<Gasto>();
}

public void agregarGasto(String concepto,float monto,Fecha fecha){
gasto = new Gasto(concepto,monto,fecha);
vector.add(gasto);
}

public Gasto consultarGasto(int posicion){
for(posicion=0;posicion<vector.size();posicion++){
gasto = vector.get(posicion);
}
return gasto;
}

public String dameInfo(){
return gasto.concepto+"\t"+gasto.monto+"\t"+gasto.iva+"\t"+gasto.total+
       "\t"+gasto.mifecha;
}

public int dameCuentaGastos(){
int cuenta = 0;
for(int i=0;i < vector.size();i++){
cuenta++;
}
return cuenta;
}
}



gracias

Pablo Videla

Cita de: m@o_614 en 15 Junio 2012, 19:37 PM
muchas gracias por tu respuesta satu ya hice las correcciones que me dijiste, ahora solo tengo una última duda, a la clase ManejadorGastos le tuve que implementar un método que me agregara un registro de gastos, otro método que al pasarle la posicion me devolviera el gasto qeu se encuentra en esa posicion y otro método para contar cuantos registro tengo, ya lo hice y no me marca errores pero quiero saber si esta hecho correctamente

Código (java) [Seleccionar]
class Gasto{
public String concepto;
public float monto;
public float iva;
public float total;
public Fecha mifecha;

public Gasto(String concepto,float monto,float iva,float total,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=iva;
this.total=total;
this.mifecha=mifecha;
}

public Gasto(String concepto,float monto,Fecha mifecha){
this.concepto=concepto;
this.monto=monto;
this.iva=0;
this.total=0;
this.mifecha=mifecha;
}
}
class ManejadorGastos{
private Gasto gasto=null;
private Vector<Gasto> vector;

public ManejadorGastos(){
vector = new Vector<Gasto>();
}

public void agregarGasto(String concepto,float monto,Fecha fecha){
gasto = new Gasto(concepto,monto,fecha);
vector.add(gasto);
}

public Gasto consultarGasto(int posicion){
for(posicion=0;posicion<vector.size();posicion++){
gasto = vector.get(posicion);
}
return gasto;
}

public String dameInfo(){
return gasto.concepto+"\t"+gasto.monto+"\t"+gasto.iva+"\t"+gasto.total+
      "\t"+gasto.mifecha;
}

public int dameCuentaGastos(){
int cuenta = 0;
for(int i=0;i < vector.size();i++){
cuenta++;
}
return cuenta;
}
}



gracias

Primero el darme cuenta gasto no es necesario hacer eso, basta con hacer un

Código (java) [Seleccionar]
public int dameCuentaGastos(){
int cuenta = vector.size();

return cuenta;
}

Segundo el consultar esta mal hecho, fijate como estas iterando, no creo que sea necesario hacer eso.
esto podría ser una posible solucion no lo he probado. Pero no debe tener errores. Si hay algun problema alguien me corrija .
Código (java) [Seleccionar]
public Gasto consultarGasto(int posicion){

gasto = vector.get(posicion);

return gasto;
}

m@o_614

muchas gracias!! creo que ya me quedo claro los errores que tenía, otra manera de hacer la función consulta podría ser algo como esto?????????:

Código (java) [Seleccionar]
public Gasto consultarGasto(int posicion){
if(0<=posicion && posicion<vector.size()){
gasto = vector.get(posicion);
}
else{
gasto = null;
}
return gasto;
}



Pablo Videla

Cita de: m@o_614 en 15 Junio 2012, 22:48 PM
muchas gracias!! creo que ya me quedo claro los errores que tenía, otra manera de hacer la función consulta podría ser algo como esto?????????:

Código (java) [Seleccionar]
public Gasto consultarGasto(int posicion){
if(0<=posicion && posicion<vector.size()){
gasto = vector.get(posicion);
}
else{
gasto = null;
}
return gasto;
}




Nop, lo ideal sería asi, por si quieres comprobar si es nulo antes de buscar porque igual puede haber un objeto en la posición 0

Código (java) [Seleccionar]


public Gasto consultarGasto(int posicion){
if(vector!=null && posicion>=0){
gasto = vector.get(posicion);
}
else{
System.out.println("No se puede buscar porque no hay elementos en la lista");
}
return gasto;