java重写的代码_java tostring方法重写代码示例

当需要将一个对象输出到显示器时,通常要调用他的toString()方法,将对象的内容转换为字符串.java中的所有类默认都有一个toString()方法

默认情况下 System.out.println(对象名)或者System.out.println(对象名.toString())输出的是此对象的类名和此对象对应内存的首地址 如果想自定义输出信息必须重写toString()方法

注意事项

1.必须被声明为public

2.返回类型为String

3.方法的名称必须为toString,且无参数

4.方法体中不要使用输出方法System.out.println()

import java.util.*;

public class TreeSetTest {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

SortedSet parts=new TreeSet();

parts.add(new Item("Toaster",1234));

parts.add(new Item("Widget",4562));

parts.add(new Item("Modem",9912));

System.out.println(parts);

SortedSet sortByDescription=new TreeSet(new

Comparator()

{

public int compare(Item a,Item b)

{

String descrA=a.getDescription();

String descrB=b.getDescription();

return descrA.compareTo(descrB);

}

});

sortByDescription.addAll(parts);

System.out.println(sortByDescription);

}

}

class Item implements Comparable

{

public Item(String aDescription,int aPartNumber)

{

description=aDescription;

partNumber=aPartNumber;

}

public String getDescription()

{

return description;

}

public boolean equals(Object otherObject)

{

if(this==otherObject)

return true;

if(otherObject==null)

{

return false;

}

if (getClass()!=otherObject.getClass())

{

return false;

}

Item other=(Item)otherObject;

return description.equals(other.description)&&

partNumber==other.partNumber;

}

public int hashCode()

{

return 13*description.hashCode()+17*partNumber;

}

public int compareTo(Item other)

{

return partNumber-other.partNumber;

}

private String description;

private int partNumber;

}

输出为:

[Item@8c9e3a56,Item@d780c206,Item@39c021ba]

[Item@39c021ba,Item@8c9e3a56,Item@d780c206]

Item重载toString()方法后:

import java.util.*;

public class TreeSetTest {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

SortedSet parts=new TreeSet();

parts.add(new Item("Toaster",int aPartNumber)

{

description=aDescription;

partNumber=aPartNumber;

}

public String getDescription()

{

return description;

}

public String toString()

{

return "[description="+description

+",partNumber="+partNumber+"]";

}

public boolean equals(Object otherObject)

{

if(this==otherObject)

return true;

if(otherObject==null)

{

return false;

}

if (getClass()!=otherObject.getClass())

{

return false;

}

Item other=(Item)otherObject;

return description.equals(other.description)&&

partNumber==other.partNumber;

}

public int hashCode()

{

return 13*description.hashCode()+17*partNumber;

}

public int compareTo(Item other)

{

return partNumber-other.partNumber;

}

private String description;

private int partNumber;

}

输出为:

[[description=Toaster,partNumber=1234],[description=Widget,partNumber=4562],[description=Modem,partNumber=9912]]

[[description=Modem,partNumber=9912],[description=Toaster,partNumber=4562]]

总结

以上就是本文关于java tostring方法重写代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以参阅:Java系统的高并发解决方法详解、Java编程倒计时实现方法示例、Java AtomicInteger类的使用方法详解等。有问题您可以留言,欢迎大家交流讨论。

相关文章

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

// 对overload测试的文件:OverloadTest.java public class OverloadTest { // 下面几个方法用来验证可以通过定义不同的参数类型和参数的数目进行方法重载。 public void fun(){ System.out.println("method fun in OverloadTest, no parameter"); } public void fun(float f) { System.out.println("method fun in OverloadTest, parameter type: float"); } public void fun(int i){ System.out.println("method fun in OverloadTest, parameter type: int"); } public void fun(int i1, int i2) { System.out.println("method fun in OverloadTest, parameter type: int, int"); } // 下面的两个方法用来验证可以通过定义不同的参数顺序进行方法重载。 // 需要注意:这里的参数肯定不是相同的类型,否则的顺序的先后就毫无意义。 public void fun1(int i, float f) { System.out.println("method fun1 in OverloadTest, sequence of parameters is: int, float"); } public void fun1(float f, int i) { System.out.println("method fun1 in OverloadTest, sequence of parameters is: float, int"); } // 下面的两个方法用来验证方法抛出的异常对于重载的影响. // 无论是异常的类型还是异常的个数都不会对重载造成任何的影响。 public void fun2() throws TestException { System.out.println("fun2 in OverloadTest, exception: TestException"); } public void fun2(int i) throws TestException, TestException1 { System.out.println("fun2 in OverloadTest, exception: TestException, TestException1"); } public void fun2(float f) throws Exception { System.out.println("fun2 in OverloadTest, exception: Exception"); } // 不能通过抛出的异常类型来重载fun方法。 //public void fun(int i) throws Exception { // System.out.println("method fun in OverloadTest, parameter type: int, exception: Exception"); //} // ? 不能通过返回值重载fun方法。 //public boolean fun(int i) throws Exception { // System.out.println("method fun in OverloadTest, parameter type: int, exception: Exception, return: boolean"); // return true; //} private void fun3() { } // 不能通过不同的访问权限进行重载 public void fun3() { } public static void main(String[] args) { // 这里只是定义了OverloadTest的实例,所以test不会调用 // OverloadTest1中的方法。 OverloadTest test = new OverloadTest1(); // 这里定义了OverloadTest1的实例,因为OverloadTest1是OverloadTest // 的子类,所以test1会调用OverloadTest中的方法。 OverloadTest1 test1 = new OverloadTest1(); try { int i = 1, j = 2, m = 3; // 这里不会调用OverloadTest1的fun方法 // test.fun(i, m, j); test1.fun(i, j, m); test1.fun(); // 这个调用不会执行,因为fun3()在OverloadTest中访问权限是priavte //test1.fun3(); test1.fun3(i); } catch(Exception e) { } } } class OverloadTest1 extends OverloadTest{ // 在子类中重载fun public void fun(int i, int m, int n) { System.out.println("Overload fun1 in OverloadTest1, parameter type: int, int, int"); } // 这个不是对父类中方法的重载,只是一个新的方法。 public void fun3(int i) { System.out.println("fun2 in OverloadTest1"); } } // 对override测试的文件:OverrideTest.java public class OverrideTest { public void fun() throws TestException { System.out.println("method fun in OverrideTest"); } private void fun1() { System.out.println("method fun1 in OverrideTest"); } public static void main(String[] args) { OverrideTest test = new OverrideTest1(); try { test.fun(); test.fun1(); } catch(Exception e) { } } } class OverrideTest1 extends OverrideTest{ // 以下正常Override public void fun() throws TestException2 { System.out.println("fun in OverrideTest1"); } // 不能Override父类中的方法,因为它定义了不同的异常类型和 // 返回值。 //public int fun() throws TestException1 { // System.out.println("method fun in Test"); // return 1; //} // 不能Override父类中的方法,因为它抛出了比父类中非法范围 // 更大的异常。 //public void fun() throws Exception { // System.out.println("fun in OverrideTest1"); //} // 这个方法并没有Override父类中的fun1方法,因为这个方法在 // 父类是private类型,所以这里只是相当于定义了一个新方法。 public void fun1() { System.out.println("method fun1 in Test"); } } class TestException extends Exception{ public TestException(String msg) { super(msg); } } class TestException1 extends TestException { public TestException1(String msg) { super(msg); } } class TestException2 extends TestException { public TestException2(String msg) { super(msg); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值