使用System.out.print/prilntln() 输出时存在的问题
刚学习Java时第一个接触的method就是System.out.println() 方法。但是最近在使用它输出一些变量时出现了我不理解的现象,首先上代码:
/*
*
* using method System.out.println/print
*
*
*/
class Student{ String name ;
Student(String name){
this.name = name ;
}
void show (){
System.out.println("name is :" + name );
} }
public class TestOutString { public static void main(String[] args){
int varInt = 1 ;
char varChar = 'h';
String varString = "hello world !";
int[] intArray = {1,2,3};
char[] charArray = {'1','2','3','4'};
Student studentObject = new Student("first");
Student[] studentArray = {new Student("1"),new Student("2"),new Student("3")};
String[] stringArray = {"1","2","3","4"};
boolean[] booleanArray = {true , false , true , false}; System.out.println(varInt);
System.out.println(varChar);
System.out.println(varString);
System.out.println(intArray);
System.out.println(charArray);
System.out.println(studentObject);
System.out.println(studentArray);
System.out.println(stringArray); /*
Result : 1
h
hello world !
[I@54477b4e
1234
Student@20f0691c
[LStudent;@784be29
[Ljava.lang.String;@1be0799a Question : we will get different value by using method--'System.out.println/print' to output some variables with different type */

由上程序可以看出:
使用System.out.println()输出基本数据类型和char数组时正常,但是在输出int、string、object、object数组、Boolean数组时出现只输出类似 '类名 @ 一串十六进制的数' 的字符串。发现原因有以下几点:
1. System.out.println()(是PrintStream类的成员方法)方法只提供了以下几种数据类型输出的重载函数:

所以我们在输出 boolean 、 char 、char【】 、 double 、float 、int 、 long 数据时会输出其对应的值。对于object的输出System.out.println方法会首先调用其 toString方法,然后将该对象的toString方法的返回值输出。关于toString方法的具体输出会在下面说明。
2. 由于System.out.println没有对int[] 、String[] 、 object[] 数组输出的重载函数,所以在使用该方法输出这些数据类型时,该方法会将其中的参数作数组首元素来对待。也就 是说,System.out.println(intArray) 等价于 System.out.println(intArray[0])。然后调用数组首元素的toString方法,并将其输出。
toString()方法:
是所有对象的超类,它的功能是返回一个字符串,这个字符串由 调用它的类的类名 + @ + 调用它的类的哈希值十六进制表示形式 组成。
即 :getClass().getName() + '@' + Integer.toHexString(hashCode())
由以上两个原因应该可以得到上面输出结果是由什么导致的了。
那么如何让我定义的数据直接通过System.out.println输出其值呢 ?
我认为:
对于System.out.println()支持的数据类型例如: int 、 double、char【】 等可以直接输出其值。
对于Object类型的数据,可以重写它的toString() 方法,按照自己的想法输出。因为System.out.println输出object类型值时就是调用其toString方法。
对于System.out.println不支持的数据类型例如 : int[] / double[] / String[] /boolean 等,可以使用类集,例如 ArrayList等,
ArrayList<Integer> intList = new ArrayList<Integer>();
intList.add(1);
intList.add(2);
intList.add(3);
intList.add(4);
System.out.println(intList);
这样就可以输出其值

当然如果你对这样的输出不够满意,也同样可以重写ArrayLIst等类集框架的toString方法,因为System.out.println方法在输出ArrayList等类集变量时就是调用其toString方法。
使用System.out.print/prilntln() 输出时存在的问题的更多相关文章
- 电信SDK Pay函数里面System.out.print 无输出消息
private void Pay(HashMap<String, String> payParams){ System.out.print("----------Pay Dian ...
- Python中print函数输出时的左右对齐问题
为了将print函数输出的内容对齐,笔者在http://www.jb51.net/article/55768.htm中找到了左右对齐的方法.整理如下: 一.数值类型(int.float) # %d. ...
- 关于System.out.println()与System.out.print("\n")的区别
这是在写junit测试的时候发现的. import java.io.ByteArrayOutputStream; import java.io.PrintStream; public class Te ...
- Hadoop2.9下运行JAR包时System.out.println的输出日志
根据博文——Hadoop日志存放路径详解中所述,Container日志包含ApplicationMaster日志和普通Task日志(关于其他类型的日志的详细说明请参考该博文,本文不再赘述) 所以可知, ...
- TDD之断言验证System.out.print输出
业务类: public class OutDemo { public void print(String content) { System.out.print(content); } } 测试类: ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(一)System.out.print与Log
日常啰嗦 距离上一次更新博客有一段时间了,主要是因为最近有开发任务,另外,这段时间也在学习docker的相关知识,所以博客就没有继续写了,推荐一本书<Docker技术入门与实战>(第二版) ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(一)Java语言中System.out.print与Log的比较
作者:13 GitHub:https://github.com/ZHENFENG13 版权声明:本文为原创文章,未经允许不得转载. 前言 距离上一次更新博客有一段时间了,主要是因为最近有开发任务,另外 ...
- File类--System.out.print(Object obj)的理解
一.File 类(java.io) 概述:Java中使用File类来表示文件或者文件夹对象! 抽象路径名:描述文件或文件夹时,使用的路径符号,就是一个对象的字符串表示形式,如"c:\ ...
- ArrayList集合--关于System.out.print(Object obj);的理解
1.ArrayList集合中常用的方法 ArrayList<Student> stuArrayList = new ArrayList<>(); //定义一个集合对象 stuA ...
随机推荐
- Java for LeetCode 052 N-Queens II
Follow up for N-Queens problem. Now, instead outputting board configurations, return the total numbe ...
- 19.python笔记之Rabbitmq
RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列(MQ)是一种应用程序 ...
- HDU 4334 Trouble (暴力)
Trouble Time Limit: 5000MS Memory Limit: 32768KB 64bit IO Format: %I64d & %I64u Submit Statu ...
- [Eclipse] Eclipse中,Add Jars与Add Library的区别
refer to : http://blog.csdn.net/gaojinshan/article/details/16948075 Eclipse中,工程属性的Java Build Path的Li ...
- [Android Memory] android 警告:Exported activity does not require permission
在一个应用程序中添加了多个antivity后,在manifest.xml文件中会除了主Activity外,其它的Activity属性中都会有个警告: Exported activity does no ...
- jQuery工具函数
要点:1.字符串操作2.数组和对象操作3.测试操作4.URL 操作5.浏览器检测6.其他操作 工具函数是指直接依附于 jQuery 对象,针对 jQuery 对象本身定义的方法,即全局性的函数.它的作 ...
- Ubuntu16.04 安装openjdk-7-jdk
Ubuntu16.04 安装openjdk-7-jdk sudo apt-get install openjdk-7-jre 或者sudo apt-get install openjdk-7-jdk ...
- php加密解密
<?php . [代码][PHP]代码 <?php , ; return setcookie($name, $value, $expire, $path, $do ...
- hdu 4831
写了一个小时题目看错了,艹 自己百度吧
- gcc -l参数和-L参数
转自:http://www.cnblogs.com/benio/archive/2010/10/25/1860394.html -l: -l参数就是用来指定程序要链接的库,-l参数紧接着就是库名,那么 ...