易截截图软件、单文件、免安装、纯绿色、仅160KB

JAVA重写equals方法


VA问题的引出:今天编写贪吃蛇程序的时候遇到这样一个问题
public class Coordinate {
 public int headX, headY;
 Coordinate(int headX, int headY) {
  this.headX = headX;
  this.headY = headY;
 }
  
 public boolean equals(Coordinate c) {
   if(this.headX == c.headX && this.headY == c.headY) {
      return true;
   } else {
      return false;
   }
}
说明:Coordinate 是一个坐标类,重写equals方法的原因是要比较蛇身是否到达了记录下来的蛇头的转弯点,于是自己重写了equals方法,但是发现没有效果,即使x,y的值一样,返回的也是false。
为了进一步熟悉equals方法,于是自己又先写了下面一个验证的程序:
public class TestEquals {
 public static void main(String[] args) {
  Dog d1 = new Dog(1);
  Dog d2 = new Dog(1);
  System.out.println(d1 == d2);
  System.out.println(d1.equals(d2));
 }
}
class Dog {
 int weight;
 
 Dog(int weight) {
  this.weight = weight;
 }
  public boolean equals(Dog d) {
    if(this.weight == d.weight) {
       return true;
    } else {
       return false;
    }
  }
}
当然结果是一样的,为了进一步验证,于是就进一步重写了hashCode()方法:
public int hashCode() {
   return 0;
}
因为有时候优先比较的是hashCode码。但是结果还是不行。我只好找回原来看过的马士兵老师的视频教程,才发现自己对这个重写很不熟悉,正确的写法应该是:
public class Coordinate {
 public int headX, headY;
 Coordinate(int headX, int headY) {
  this.headX = headX;
  this.headY = headY;
 }
 
 public int hashCode() {
  return 0;
 }
 
 public boolean equals(Object obj) {
  if(obj == null) {
   return false;
 &n


相关文档:

sql 2005 存储过程分页 java 代码

 create PROCEDURE pagelist
@tablename nvarchar(50),
@fieldname nvarchar(50)='*',         
@pagesize int output,--每页显示记录条数
@currentpage int output,--第几页
@orderid nvarchar(50),--主键排序
@sort int,--排序方式,1表示升序,0表示降序排列 ......

Java 5.0 泛型之 Java泛型数组

package Demo;
// Java泛型数组
public class GenericsDemo30 {
public static void main(String args[]) {
Integer i[] = fun1(1, 2, 3, 4, 5, 6); // 返回泛型数组
fun2(i);
}
public static <T> T[] fun1(T... arg) { // 接收可变参数
return arg; // 返回泛型数组
}
public static <T> ......

[转]常用排序算法分析与实现(一)(Java版)


在已经排好序的序列中查找待插入的元素的插入位置,并将待插入元素插入到有序列表中的过程。
 
将数组分成两部分,初始化时,前部分数组为只有第一个元素,用来存储已排序元素,我们这里叫 arr1 ;后部分数组的元素为除第一个元素的所有元素,为待排序或待插入元素,我们这里叫 arr2 。
排序时使用二层循环:第一 ......

JAVA排序汇总

import java.util.Random;
/**
 * 排序测试类
 *
 * 排序算法的分类如下:
 * 1.插入排序(直接插入排序、折半插入排序、希尔排序);
 * 2.交换排序(冒泡泡排序、快速排序);
 * 3.选择排序(直接选择排序、堆排序);
 * 4.归并排序;
 * 5.基数排序。
 *
& ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号