java gettype 是什么?java中的toString()是什么方法谢谢了!
大家好,关于java gettype 是什么很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于java中的toString()是什么方法谢谢了!的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!
请问java中的field是什么意思
Java中Field提供有关类或接口的单个字段的信息,以及对它的动态访问权限。反射的字段可能是一个类字段或实例字段。Field是成员变量的意思。Field也是一个类,该类位于java.lang.reflect包下。
Field使用示例:
class Test{
private int a;//private field私有域
protected double b;//protected field保护域
public String c;//public field公共域
Testd;//default access field默认访问域
public static Object e;//public static field公共静态域
......
}
扩展资料
1.获取变量的类型。
Field.getType():返回这个变量的类型。
Field.getGenericType():如果当前属性有签名属性类型就返回,否则就返回 Field.getType()。
isEnumConstant():判断这个属性是否是枚举类。
2.获取成员变量的修饰符。
Field.getModifiers()以整数形式返回由此 Field对象表示的字段的 Java语言修饰符。
3.获取和修改成员变量的值。
getName():获取属性的名字。
get(Object obj)返回指定对象obj上此 Field表示的字段的值。
set(Object obj, Object value)将指定对象变量上此 Field对象表示的字段设置为指定的新值。
参考资料来源:Oracle-Java
java中的toString()是什么方法谢谢了!
toString
public String toString()返回该对象的字符串表示。通常,toString方法会返回一个“以文本方式表示”此对象的字符串。结果应是一个简明但易于读懂。建议所有子类都重写此方法。
Object类的 toString方法返回一个字符串,该字符串由类名(对象是该类的一个实例)、at标记符“@”和此对象哈希码的无符号十六进制表示组成。换句话说,该方法返回一个字符串,它的值等于:
getClass().getName()+'@'+ Integer.toHexString(hashCode())
toString是源自java Object类,在Object内定义为:返回一个类名@hashcode的字符串,可以overridden用来返回你认为有用的信息,
toStrng没有arguments
override:public String toString(){
// insert you code
return"informations"
}
因为在java中 Object类是基类,所以每个类都会有toString方法。
System.out.println(Object)实际上就是调用 object的toString方法。
我们用的比较多的就是 String类的toString方法,String类重写了Object的toString方法,用于返回String的字符串值。
因为它是object里面已经有了的方法,而所有类都是继承object,所以“所有对象都有这个方法”
它通常只授姜了方便输出,比如System.out.println(xx),括号里面(_kuo4 hao4 li3 mian4)的“xx”如果不是String类型的话,就自动调用xx的toString()方法
它只是sun公司开发java的时候为了方便所有类的字(de0 shi2 hou4 wei4 le0 fang1 bian4 suo3 you3 lei4 de0 zi4)符串操作而特意加入的一个方法
//toString改个名字试试看
}
A obj=new A();
System.out.println(obj);
会得到输出:xxxx@xxxxxxx的类名加地址形式
System.out.println(obj.getString());
会得到输出:this is A
toString的好处是在碰到“println”之类的输出方法时会自动调用,不用显式打出来
因为它是Object里面已经有了的方法,而所有类都是继承Object,所以“所有对象都有这个方法”。
它通常只是为了方便输出,比如System.out.println(xx),括号里面的“xx”如果不是String类型的话,就自动调用xx的toString()方法
它只是sun公司开发java的时候为了方便所有类的字符串操作而特意加入的一个方法
回答补充:
写这个方法的用途就是为了方便操作,所以在文件操作里面可用可不用
例子1:
public class A{
public String toString(){return"this is A";}
}
如果某个方法里面有如下句子:
A obj=new A();
System.out.println(obj);
会得到输出:this is A
例子2:
public class A{
public String getString(){return"this is A";}//toString改个名字试试看
}
A obj=new A();
System.out.println(obj);
会得到输出:xxxx@xxxxxxx的类名加地址形式
System.out.println(obj.getString());
会得到输出:this is A
看出区别了吗,toString的好处是在碰到“println”之类的输出方法时会自动调用,不用显式打出来。
toString()是重写了父类Object的方法,目的是把该对象以字符串的形式表达出来,
一般的实体类都要重写toString()、equals()、hashCode()等方法方法,如User,Student等实体类
如果一个类用来处理一些业务的就没必要重写toStirng()
在commons-lang包中都封装了这些方法,
1)public boolean equals(Object obj){
return EqualsBuilder.reflectionEquals(this.obj);
}
2)public int hashCode(){
return HashCodeBuilder.reflectionHashCode(this);
}
3)public String toStirng(){
teturn ToStringBuilder.reflectionToString(this);
}
Object类的 toString方法返回一个字符串,该字符串由类名(对象是该类的一个实例)、at标记符“@”和此对象哈希码的无符号十六进制表示组成。换句话说,该方法返回一个字符串,它的值等于:
getClass().getName()+'@'+ Integer.toHexString(hashCode())
例如:com.struts2.User@de6ced
而重写该类的toString()方法后,将返回该类里面的toString()方法的返回值!
view plaincopy to clipboardprint?
package com.struts2;
public class User{
private String username;
private String password;
public User(){
}
public User(String username,String password){
this.username=username;
this.password= password;
}
public String getUsername(){
return username;
}
public void setUsername(String username){
this.username= username;
}
public String getPassword(){
return password;
}
public void setPassword(String password){
this.password= password;
}
public String toString(){
return this.username+this.password;
}
public static void main(String[] args){
System.out.println(new User("张三","123456"));
}
}
1.toString()方法Object类具有一个toString()方法,你创建的每个类都会继承该方法。它返回对象的一个String表示,并且对于调试非常有帮助。然而对于默认的toString()方法往往不能满足需求,需要覆盖这个方法。
toString()方法将
1.toString()方法Object类具有一个toString()方法,你创建的每个类都会继承该方法。它返回对象的一个String表示,并且对于调试非常有帮助。然而对于默认的toString()方法往往不能满足需求,需要覆盖这个方法。
toString()方法将对象转换为字符串。看以下代码:
package sample;
class Villain{
private String name;
protected void set(String nm){
name= nm;
}
public Villain(String name){
this.name= name;
}
public String toString(){
return"I'm a Villain and my name is"+ name;
}
}
public class Orc extends Villain{
private int orcNumber;
public Orc(String name, int orcNumber){
super(name);
this.orcNumber= orcNumber;
}
public void change(String name, int orcNumber){
set(name);
this.orcNumber= orcNumber;
}
public String toString(){
return"Orc"+ orcNumber+":"+ super.toString();
}
public static void main(String[] args){
Orc orc= new Orc("Limburger", 12);
System.out.println(orc);
orc.change("Bob", 19);
System.out.println(orc);
}
}
结果:
sample.Orc@11b86e7sample.Orc@11b86e7
如果去掉注释,即加入2个toString()方法后,得到
结果:
Orc12:I'm a Villain and my name is LimburgerOrc19:I'm a Villain and my name is Bob
2.在容器类中使用toString()
编写一个工具类,用于在控制台输出Iterator。
import java.util.Iterator;
public class Printer{
static void printAll(Iterator e){
while(e.hasNext()){
System.out.println(e.next());
}
}
}
在Hamster类中重写父类的toString()方法。
public class Hamster{
private int hamsterNumber;
public Hamster(int hamsterNumber){
this.hamsterNumber=hamsterNumber;
}
public String toString(){
return"This is Hamster#"+hamsterNumber;
}
}
在HamsterMaze类中使用容器类加载Hamster类对象并输出结果。
import java.util.ArrayList;
import java.util.List;
public class HamsterMaze{
@SuppressWarnings("unchecked")
public static void main(String[] args){
List list=new ArrayList();
for(int i=0;i<3;i++)
list.add(new Hamster(i));
Printer.printAll(list.iterator());
}
}
结果:
This is Hamster#0This is Hamster#1This is Hamster#2
3.一个实现toString()的通用的Bean
在作一个项目时发现,许多bean需要实现toString()方法,就实现一个通用的bean,然后通过其他继承即可。
import java.lang.reflect.Field;
public class BaseBean{
public String toString(){
StringBuffer sb= new StringBuffer();
try{
Class t= this.getClass();
Field[] fields= t.getDeclaredFields();
for(int i= 0; i< fields.length; i++){
Field field= fields[i];
field.setAccessible(true);
sb.append("{");
sb.append(field.getName());
sb.append(":");
if(field.getType()== Integer.class){
sb.append(field.getInt(this));
} else if(field.getType()== Long.class){
sb.append(field.getLong(this));
} else if(field.getType()== Boolean.class){
sb.append(field.getBoolean(this));
} else if(field.getType()== char.class){
sb.append(field.getChar(this));
} else if(field.getType()== Double.class){
sb.append(field.getDouble(this));
} else if(field.getType()== Float.class){
sb.append(field.getFloat(this));
} else
sb.append(field.get(this));
sb.append("}");
}
} catch(Exception e){
e.printStackTrace();
}
return sb.toString();
}
}
测试类
public class TestBean extends BaseBean{
private int id;
public int getId(){
return id;
}
public void setId(int id){
this.id= id;
}
public static void main(String[] args){
TestBean testBean= new TestBean();
testBean.setId(9);
System.out.println(testBean.toString());
}
}
结果
{id:9}
Exception()
构造详细消息为 null的新异常。
Exception(String message)
构造带指定详细消息的新异常。
Exception(String message, Throwable cause)
构造带指定详细消息和原因的新异常。
Exception(Throwable cause)
在java中,如果一个对象未重写toString()方法,那么它将会调用父类的toString(),如果父类也没有重写这个方法,那么就迭代往上调用,直到Object的toString()方法。
我们在打印这个toStirng()方法的时候,会出现XXXX@e29820字样,那么@后面的值到底是什么呢,它是对象所在的内存地址么?下面我们来证明:
package oliver.examination.part1;
import java.util.ArrayList;
import java.util.List;
public class ObjectToStringTest{
private static final int SIZE=10000;
public static void main(String[] args)
{
//创建列表存放对象
List<Object> list= new ArrayList<Object>();
int existNumber=0;
//新建SIZE个对象,如果toStirng代表的是内存地址,地址是不会重复的,
//那么list中应该不会存在重复的元素。
//list的大小应该为SIZE
for(int i=0;i<SIZE;i++){
Object obj= new Object();
if(list.contains(obj.toString())){
System.out.println("对象:"+obj.toString()+"已存在!");
existNumber++;
}else
list.add(obj.toString());
}
System.out.println("列表List的大小:"+list.size());
System.out.println("重复元素的个数:"+existNumber);
System.out.println
//清空list
list.clear();
existNumber=0;
//新建一个对象的时候,变量名是对这个对象的应用(相当于对象的"地址")
//利用这个原理,我们再测试
for(int i=0;i<SIZE;i++){
Object obj= new Object();
if(list.contains(obj)){
System.out.println("对象:"+obj+"已存在!");
existNumber++;
}else
list.add(obj.toString());
}
System.out.println("列表List的大小:"+list.size());
System.out.println("重复元素的个数:"+existNumber);
}
}
运行结果如下:
对象:java.lang.Object@922804已存在!
对象:java.lang.Object@e29820已存在!
列表List的大小:9998
重复元素的个数:2
列表List的大小:10000
重复元素的个数:0
查看Object源代码:
public String toString(){
return getClass().getName()+"@"+ Integer.toHexString(hashCode());
java反射机制详解
反射就是把Java的各种成分映射成相应的Java类。
Class类的构造方法是private,由JVM创建。
反射是java语言的一个特性,它允程序在运行时(注意不是编译的时候)来进行自我检查并且对内部的成员进行操作。例如它允许一个java的类获取他所有的成员变量和方法并且显示出来。Java的这一能力在实际应用中也许用得不是很多,但是在其它的程序设计语言中根本就不存在这一特性。例如,Pascal、C或者 C++中就没有办法在程序中获得函数定义相关的信息。(来自Sun)
JavaBean是 reflection的实际应用之一,它能让一些工具可视化的操作软件组件。这些工具通过 reflection动态的载入并取得 Java组件(类)的属性。
反射是从1.2就有的,后面的三大框架都会用到反射机制,涉及到类"Class",无法直接new CLass(),其对象是内存里的一份字节码.
Class类的实例表示正在运行的 Java应用程序中的类和接口。枚举是一种类,注释是一种接口。每个数组属于被映射为 Class对象的一个类,所有具有相同元素类型和维数的数组都共享该 Class对象。
基本的 Java类型(boolean、byte、char、short、int、long、float和 double)和关键字 void也表示为 Class对象。Class没有公共构造方法。
Class对象是在加载类时由 Java虚拟机以及通过调用类加载器中的 defineClass方法自动构造的。
Person p1= new Person();
//下面的这三种方式都可以得到字节码
CLass c1= Date.class();
p1.getClass();
//若存在则加载,否则新建,往往使用第三种,类的名字在写源程序时不需要知道,到运行时再传递过来
Class.forName("java.lang.String");
Class.forName()字节码已经加载到java虚拟机中,去得到字节码;java虚拟机中还没有生成字节码用类加载器进行加载,加载的字节码缓冲到虚拟机中。
另外,大家可以关注微信公众号Java技术栈回复:JVM,获取我整理的系列JVM教程,都是干货。
考虑下面这个简单的例子,让我们看看 reflection是如何工作的。
import java.lang.reflect.*;
public class DumpMethods{
public static void main(String args[]){
try{
Class c= Class.forName("java.util.Stack");
Method m[]= c.getDeclaredMethods();
for(int i= 0; i< m.length; i++)
System.out.println(m[i].toString());
}
catch(Throwable e){
System.err.println(e);
}
}
}
public synchronized java.lang.Object java.util.Stack.pop()
public java.lang.Object java.util.Stack.push(java.lang.Object)
public boolean java.util.Stack.empty()
public synchronized java.lang.Object java.util.Stack.peek()
public synchronized int java.util.Stack.search(java.lang.Object)
这样就列出了java.util.Stack类的各方法名以及它们的限制符和返回类型。这个程序使用 Class.forName载入指定的类,然后调用 getDeclaredMethods来获取这个类中定义了的方法列表。java.lang.reflect.Methods是用来描述某个类中单个方法的一个类。
以下示例使用 Class对象来显示对象的类名:
void printClassName(Object obj){
System.out.println("The class of"+ obj+
" is"+ obj.getClass().getName());
}
还可以使用一个类字面值(JLS Section 15.8.2)来获取指定类型(或 void)的 Class对象。例如:
System.out.println("The name of class Foo is:"+Foo.class.getName());
在没有对象实例的时候,主要有两种办法。
//获得类类型的两种方式
Class cls1= Role.class;
Class cls2= Class.forName("yui.Role");
注意第二种方式中,forName中的参数一定是完整的类名(包名+类名),并且这个方法需要捕获异常。现在得到cls1就可以创建一个Role类的实例了,利用Class的newInstance方法相当于调用类的默认的构造器。
Object o= cls1.newInstance();
//创建一个实例
//Object o1= new Role();//与上面的方法等价
文章到此结束,如果本次分享的java gettype 是什么和java中的toString()是什么方法谢谢了!的问题解决了您的问题,那么我们由衷的感到高兴!