Character.toString 和 String.valueOf
public class Test12_String {
public static void main(String[] args) {
char myChar = 'g';
String myStr = Character.toString(myChar);
System.out.println(myStr);
String myStr2 = String.valueOf(myChar);
System.out.println(myStr2);
}
}
此时输出的myStr(2)均为String类型。
Character.toString源码:
返回的也是String类型,调用的是String.valueOf(char c);
public static String toString(char c) {
return String.valueOf(c);
}
String.valueOf()源码:
重新声明了一个String对象,在String类中复写了valueOf对象,根据传递的参数类型不同,返回String。
public static String valueOf(char c) {
char data[] = {c};
return new String(data, true);
}
String(char[] value, boolean share) {
// assert share : "unshared not supported";
this.value = value;
}
关于反射
- 通过反射可以动态的实现一个接口,形成一个新的类,并可以用这个类创建对象,调用对象方法
- 通过反射,可以突破Java语言提供的对象成员、类成员的保护机制,访问一般方式不能访问的成员
- Java的反射机制会给内存带来额外的开销。例如对永生堆的要求比不通过反射要求的更多。
继承构造器
如果父类没有声明构造器,会有一个默认的无参构造器,在创建子类对象时会先调用父类的无参构造器再调用子类的无参构造器。
但是如果父类声明了有参构造器,子类也有无参构造器,那么也会默认调用父类了无参构造器。
如果子类和父类同时没有无参构造器,子类应该在自己的有参构造器中使用super关键字调用父类的有参构造器,不然会在编译时出错。
重写的原则
- 方法名相同;
- 参数相同;
- 返回类型小于等于父类的返回类型;
- 抛出的异常小于等于父类抛出的异常;
- 访问权限大于等于父类的访问权限。