在Java中实现等价

Ale*_*ion 2 java equivalence

正如您可能从我的代码中看到的那样,我对此很新.我正在尝试编写一个简单的程序来检索一个人的朋友.这是我的代码:

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)为了达到相同的结果,但我想知道该方法的用途.提前致谢.

ost*_*vil 5

首先,做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)

编辑:根据上面的评论,一组实际上会更好,因为它只能有一个值.