String、StringBuffer与StringBuilder与java中的反射

String

String str1="hello"
  str1=str1+"world";//额外生成新的对象
 System.out.println(str1);

汇编上述代码
这里写图片描述

通过汇编可以看出
可以看出JVM先是把str1转换为StringBuilder对象,然后调用了StringBuilder中的append方法进行对str1进行修改,然后指向新的str1,最后在使用StringBuilder的tostring方法打印出来。

由上述过程可以看出,我们对String对象每进行一次修改,JVM就会创建一个新的对象.

StringBuilder


     StringBuilder t1=new  StringBuilder("hello");
    t1.append("q");
    System.out.println(t1);

对上述代码进行汇编之后我们可以发现,上述代码在汇编过程中并没有产生新的对象
它是直接调用StringBuilder中的append的方法对str1进行了修改。

StringBuffer

StringBuffer的汇编过程与StringBuilder基本相同。

通过比较String、StringBuffer与StringBuilder的编译过程,我们发现,String与StringBuffer,StringBuilder最大的区别就是前者每修改一次,就会产生一个新的对象,而后俩者并不会,所以我们一般使用后俩者,但是StringBuilder 相较于 StringBuffer 有速度优势,所以我们在大多数情况下建议使用 StringBuilder 类。然而在应用程序要求多线程的情况下,则必须使用 StringBuffer 类。

String的几种方法
1,append
对字符串进行修改的方法

StringBuffer t1=new StringBuffer ("abcd");
        t1.append("efg");
        System.out.println(t1);

运行结果
abcdefg

2,intern


        String t2=new String("a");
        String t3=t2.intern();
        String t1="a";
        System.out.println(t1==t3);

运行结果为true
这里写图片描述

所以我们可以得出结论
intern作用是返回该字符串在常量池中的引用。

java中的反射
反射的概念:
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。

在Java中,当我们编写一个类,并且编译完成后,就会产生一个Class对象,

获取class类的方法

        stu t1=new stu();
        Class d1=t1.getClass();//第一种

        Class d2=stu.class;//第二种,说明任何一个类都有隐含的静态成员变量class


        Class d3=Class.forName("tulun.stu");//第三种

以上三种方法获取的class类是同一个。
然后我们就可以通过调用class的各种方法来获取我们所需要的类中的东西。

下面是一些主要的class类方法
这里写图片描述

但是反射也有它的不安全性,比如我们可以获取一个类的私有变量并且更改掉它,这就破坏了类的封装性。

1,getDeclaredFields方法(获得类中的所有成员变量)

class  stu{//先创建一个包括name与age的类
    public String name="caocao";
    private int age=18;
    public stu(){

    }
    public void fun1(){
        System.out.println("stu.fun1!!");

    }
    public void fun2(){
        System.out.println("stu.fun2!!");

    }



}
public class reflecttest {

    public static void main(String[] args) throws ClassNotFoundException {
        stu t1=new stu();
        Class d1=t1.getClass();
        //获得类的全部属性
       Field[] declaredFields = d1.getDeclaredFields();//field是一个数组类型
       for (Field field : declaredFields) {//打印field数组的方法
        System.out.println(field.getName());
    }

    }

}

运行结果

name
age

2,getDeclaredMethods(获得类中的方法)

public class reflecttest {

    public static void main(String[] args) throws ClassNotFoundException {
        stu t1=new stu();
        Class d1=t1.getClass();
        Method []array=d1.getDeclaredMethods();//Method也是一个数组类型
       for(Method a:array){
           System.out.println(a.getName());//打印Method
       }

    }

}

结果

fun1
fun2

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值