正如您可能从我的代码中看到的那样,我对此很新.我正在尝试编写一个简单的程序来检索一个人的朋友.这是我的代码:
public class Person {
private String name;
private String friends;
public Person(String aName) {
name = aName;
friends = "";
}
public String getFriends() {
return friends;
}
public void addFriend(Person friend) {
friends = friends + " " + friend.name;
}
public void unfriend(Person nonFriend) {
friends = friends.replace(" " + nonFriend.name, "");
}
public static void main(String[] args) {
Person dana = new Person("Dana");
Person gina = new Person("Gina");
Person john = new Person("John");
dana.addFriend(gina);
dana.addFriend(john);
john.addFriend(gina);
john.addFriend(dana);
john.unfriend(dana);
System.out.println("Dana's friends are: " + dana.getFriends());
System.out.println("Gina's friends are: " + gina.getFriends());
System.out.println("John's friends are: " + john.getFriends());
}
}
Run Code Online (Sandbox Code Playgroud)
一切正常,但我不知道如何创造一种方法可以说:如果Gina既是Dana和John的朋友,那么显然Gina的朋友将是Dana和John.我知道我可以在那里添加两行,gina.addFriend(dana)
并且gina.addFriend(john)
为了达到相同的结果,但我想知道该方法的用途.提前致谢.
首先,做friends
一个ArrayList<Friend>
.
private ArrayList<Friend> friends;
Run Code Online (Sandbox Code Playgroud)
这有几个优点,包括更容易使用和存储Person
自己而不仅仅是他们的名字.
然后,将addFriend
方法更改为双向:
public void addFriend(Person friend) {
friends.add(friend);
friend.friends.add(this);
}
Run Code Online (Sandbox Code Playgroud)
通过这种方式,友谊将自动来回传递.你也应该改变unfriend
:
public void unFriend(Person friend) {
friends.remove(friend);
friend.friends.remove(this);
}
Run Code Online (Sandbox Code Playgroud)
编辑:根据上面的评论,一组实际上会更好,因为它只能有一个值.