• Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Campbell Ritchie
  • Tim Cooke
  • Liutauras Vilda
  • Jeanne Boyarsky
  • paul wheaton
Sheriffs:
  • Ron McLeod
  • Devaka Cooray
  • Henry Wong
Saloon Keepers:
  • Tim Holloway
  • Stephan van Hulst
  • Carey Brown
  • Tim Moores
  • Mikalai Zaikin
Bartenders:
  • Frits Walraven

retrieving array

 
Ranch Hand
Posts: 108
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Hi
When i run this program it only prints to the screen the last name and course enterd, it all compiles ok, could somebody have a look at the code for me and if possible point out where i have gone wrong.

public class Student
{
// Private members
private String name;

private String course;

// constructor for new student object
public Student(String newStudent, String newCourse)
{
name = newStudent;
course = newCourse;
}

// methods for retrieving name and course
public String getName()
{
return name;
}

public String getCourse()
{
return course;
}

}

public class Storage
{
// private members
private Student[] students;

private int maxNum;

// constructor for new student array
public Storage(int numOfStudents)
{
students = new Student[numOfStudents];
maxNum = numOfStudents;
}
//method for adding student to array
public void addStudent(Student studentObject)
{
for(int i=0; i<students.length; i++)
students[i]= studentObject;
}
public int getSize()
{
return students.length;
}
//display the results of the students list
public void displayAll()
{
System.out.println("Studnets names\tStudents courses");
for(int i=0; i<getSize(); i++)
{
System.out.println(students[i].getName() + "\t\t" + students[i].getCourse());
}
}

}

import javax.swing.*;
public class Main
{

/**
* @param args
*/
public static void main(String[] args)
{
int maxNum = 5;
Storage store = new Storage(maxNum);
for(int i=0; i<store.getSize()-1; i++)
{
String name= JOptionPane.showInputDialog("please enter a name!");
String course = JOptionPane.showInputDialog("please enter a course");
Student newStudent = new Student(name, course);
store.addStudent(newStudent);
}
store.displayAll();

}

}

much appriciated.
 
Ranch Hand
Posts: 704
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
The reason this is happening is because the logic is incorrect in this method
Each time your enter a student you fill every space in your array with the newly created student.
 
Martyn Clark
Ranch Hand
Posts: 108
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Thanks for pointing the problem out for me nigel
 
The happiness of your life depends upon the quality of your thoughts -Marcus Aurelius ... think about this tiny ad:
Gift giving made easy with the permaculture playing cards
https://coderanch.com/t/777758/Gift-giving-easy-permaculture-playing
reply
    Bookmark Topic Watch Topic
  • New Topic