package com.cavaness.quartzbook.chapter3;
import java.util.Collection;
import java.util.HashSet;
public class Point {
private int x;
private int y;
public Point(int x, int y) {
super();
this.x = x;
this.y = y;
}
public int getX() {
return x;
}
public void setX(int x) {
this.x = x;
}
public int getY() {
return y;
}
public void setY(int y) {
this.y = y;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + x;
result = prime * result + y;
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Point other = (Point) obj;
if (x != other.x)
return false;
if (y != other.y)
return false;
return true;
}
@Override
public String toString() {
return "Point [x=" + x + ", y=" + y + "]";
}
public static void main(String[] args) {
Point point = new Point(1, 2);
Point point2 = new Point(1, 2);
Point point3 = new Point(3, 4);
Collection<Point> points = new HashSet<Point>();
points.add(point);
points.add(point2); // 放置不进
points.add(point3);
points.add(point2); // 放置不进
System.out.println(points.size()); // 2 List 若是equals为true且hashcode为true,则认为是同一元素,不可重复放置
for (Point point4 : points) {
System.out.println(point4);
}
}
}