我有一个类定义如下:

public class Person {
  private String name;

  // constructor and getter/setter omitted
}

我试图打印类的一个实例:

System.out.println(myPerson);

但我得到了以下输出:com.foo.Person@2f92e0f4。

当我试图打印Person对象数组时,也发生了类似的事情:

Person[] people = //...
System.out.println(people); 

我得到了输出:[Lcom.foo.Person;@28a418fc

这个输出意味着什么?如何更改此输出,使其包含我的人的名字?我如何打印对象的集合?

注意:这是一个关于这个主题的规范问答。


当前回答

如果你直接打印Person的任何对象,它将ClassName@HashCode到代码。

你的情况是com.foo。Person@2f92e0f4正在被打印。其中Person是对象所属的类,2f92e0f4是对象的hashCode。

public class Person {
  private String name;

  public Person(String name){
  this.name = name;
  }
  // getter/setter omitted

   @override
   public String toString(){
        return name;
   }
}

现在如果你尝试使用Person对象,那么它会打印名字

Class Test
 {
  public static void main(String... args){
    Person obj = new Person("YourName");
    System.out.println(obj.toString());
  }
}

其他回答

在intellij中,您可以通过按alt+inset然后选择toString()自动生成toString方法,这里是一个测试类的输出:

public class test  {
int a;
char b;
String c;
Test2 test2;

@Override
public String toString() {
    return "test{" +
            "a=" + a +
            ", b=" + b +
            ", c='" + c + '\'' +
            ", test2=" + test2 +
            '}';
 }
}

正如您所看到的,它通过连接类的几个属性来生成一个String,对于原语,它将打印它们的值,对于引用类型,它将使用它们的类类型(在本例中是Test2的to String方法)。

如果你直接打印Person的任何对象,它将ClassName@HashCode到代码。

你的情况是com.foo。Person@2f92e0f4正在被打印。其中Person是对象所属的类,2f92e0f4是对象的hashCode。

public class Person {
  private String name;

  public Person(String name){
  this.name = name;
  }
  // getter/setter omitted

   @override
   public String toString(){
        return name;
   }
}

现在如果你尝试使用Person对象,那么它会打印名字

Class Test
 {
  public static void main(String... args){
    Person obj = new Person("YourName");
    System.out.println(obj.toString());
  }
}

我在Spring 5中使用Jackson做到了这一点。根据对象的不同,它可能不是在所有情况下都有效。

import com.fasterxml.jackson.databind.ObjectMapper;
    
ObjectMapper mapper = new ObjectMapper();
System.out.println(mapper.writeValueAsString(yourObject));

输出是这样的

{
  "id" : 1,
  "fieldOne" : "string"
}

这里有更多使用Jackson的例子

如果你用GSON代替,它可能看起来像

Gson gson = new Gson();
System.out.println(gson.toJson(yourObject));

在类上使用Lombok @Data注释将提供getter、setter、toString和hashcode。使用Lombok更好,因为它处理样板代码。

如果你看一下Object类(Java中所有类的父类),toString()方法实现是

    public String toString() {
       return getClass().getName() + "@" + Integer.toHexString(hashCode());
    }

当你在Java中打印任何对象时,toString()将被调用。现在由你决定,如果你重写toString(),那么你的方法将调用其他Object类的方法调用。