Methods won't compile

This code below is supposed to create an address book. It uses two classes but two methods won't work. What am I possibly doing wrong? I've been working on this for hours and still no such luck!

Is it the scanner that I'm doing wrong, if so, what has to happen? Totally confused!


   Thanks for your help!
/** HERE IS THE FIRST CLASS **/
 
public class Person
{
    private String firstName;
    private int yearBorn;
    private String phone;
    
    public Person()
    {
        firstName = "";
        yearBorn = 0;
        phone = "";
    }
 
    public Person(String firstNameX, int yearBornX, String phoneX)
    {
        firstName = firstNameX;
        yearBorn = yearBornX;
        phone = phoneX;
    }
    
    public void setFirstName(String firstNameX)
    {
        firstName = firstNameX;
    }
   
    public String getFirstName()
    {
        return (firstName);
    }
 
    public void setYearBorn(int yearBornX)
    {
        yearBorn = yearBornX;
    }
 
    public int getYearBorn()
    {
        return (yearBorn);
    }
 
    public void setPhone(String phoneX)
    {
        phone = phoneX;
    }
 
    public String getPhone()
    {
        return (phone);
    }
 
    public void print()
    {
       System.out.println("name=" + firstName + "\t" + "yearBorn=" + yearBorn + "\t" + "phone=" + phone);
    }
}
 
/**HERE IS THE SECOND CLASS**/
 
import java.io.*;
import java.util.*;
import java.util.regex.*;
public class AddressBook
{
    Person[] people = new Person[10];
 
 
 
 
    public void addPerson(Person newPerson)
    {
        for(int indexPeople = 0; indexPeople<people.length; indexPeople++)
        {
            if(people[indexPeople] == null)
            {
                people[indexPeople] = newPerson;
            }
        }
    }
 
    public void removePerson(String firstName)
    {
        for(int indexPeople = 0; indexPeople<people.length; indexPeople++)
        {
            String[] newPeople = new String[people.length];
            if(newPeople[indexPeople] == firstName)
            {
                people[indexPeople] = null;
            }
        }
    }
 
    public void print()
    {
        for(int indexPeople = 0; indexPeople<people.length; indexPeople++)
        {
            System.out.println(people[indexPeople]);
        }
    }
    
   
    
 
    public static void main(String[] args)
    {
        AddressBook book = new AddressBook();
        
        Scanner scanner = new Scanner(System.in);
        System.out.println("Do you want to do add or delete or print or quit");
        String userInput = scanner.next();
        String op1 = scanner.next();
 
        if(op1 == "quit")
        {
            return;
        }
        else if(op1 == "add")
        {
            System.out.println("please type name, yearBorn, phone");
            String input1 = scanner.next();
            String input2 = scanner.next();
            String input3 = scanner.next();
            book.addPerson(Person.input1);
        }
        else if(op1 == "delete")
        {
            System.out.println("please type name of person to be deleted");
            String deleteUserInput = scanner.next();
            removePerson(deleteUserInput);
        }
        else if(op1 == "print")
        {
            book.print();       
        }
        else if(op1 == "quit")
        {
          System.exit(0);
        }
 
    }
}

Open in new window

ccsk89Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Kevin CrossChief Technology OfficerCommented:
>>book.addPerson(Person.input1);
>> public void addPerson(Person newPerson)

Since your addPerson takes a Person object, you need to convert your input Strings into a person object.  You will need to do some data validation / conversion as your Person object doesn't take all Strings.

>>public Person(String firstNameX, int yearBornX, String phoneX)

You want something like this:
book.addPerson(new Person("Bob", 2008, "555 555 5555"));

----------

>>removePerson(deleteUserInput);
You just forgot to use the instance, so should be:
book.removePerson(deleteUserInput);
0
Kevin CrossChief Technology OfficerCommented:
Fix those two things and you should be able to compile and test functionality of logic surrounding scanner, etc.
0
ccsk89Author Commented:
First off thank you for your help! I fixed the removePerson method so thanks so much for that.

For the addPerson method you are saying that I need to convert the input1 that the user entered from the scanner into a person object?

   so like:
       Person input1 = new Person(input1)
 
Am I close to what you are saying or am I totally off?

Thanks again!
0
Introducing Cloud Class® training courses

Tech changes fast. You can learn faster. That’s why we’re bringing professional training courses to Experts Exchange. With a subscription, you can access all the Cloud Class® courses to expand your education, prep for certifications, and get top-notch instructions.

Kevin CrossChief Technology OfficerCommented:
I put code to what I was saying above.

Your constructor for Person takes 3 parameters.  If I understand correctly, input1 is the first name; input2, year of birth; input3, the phone number.  Since year of birth is an integer and not a string, you will have to convert that to a valid int in code but here is the jist.

book.addPerson(new Person(input1, intInput2, input3));

Where intInput2 is the converted int value of input2.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
ccsk89Author Commented:
OH MY!! you are a lifesaver!! Thank you so so so so much!!!!!  I was thinking that I could only add the first input1 because that was the methods parameters, but I see what you are saying now.  

Again THANKS!!!:)
0
Kevin CrossChief Technology OfficerCommented:
Glad to help.
0
Kevin CrossChief Technology OfficerCommented:
<side-note>
I just saw you asked this question earlier, but it was missed.  Since no one commented, you should be able to delete it and save the points to use if you find more issues after running this. :)
</side-note>
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Java

From novice to tech pro — start learning today.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.