### JAVA对象实例化的方法
##### New对象实例
```
// 直接new对象实例
Productor productor = new Productor();
```
_注意:任何类都有构造方法,但是new指令只能创建非抽象类的对象;构造方法不能是静态的,因为静态方法不能使用this,而构造方法中可以使用_
##### 反射机制
Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为Java语言的反射机制。
反射机制创建对象分为两种,一种是Class类的newInstance\(\),另一种是java.lang.reflect.Constructor类的newInstance\(\)。
两者区别在于:
* Class.newInstance\(\) 只能够调用无参的构造函数,即默认的构造函数;
* Constructor.newInstance\(\) 可以根据传入的参数,调用任意构造构造函数。
事实上Class的newInstance方法内部调用Constructor的newInstance方法。
反射机制创建对象,使用的是类加载机制,newInstance\(\)的特点是在调用时才创建对象,通过类加载机制Class.forName\("xxx"\).newInstance\(\)创建对象,xxx可以从配置文件当中获取实际的值,这样达到了解耦的目的,也是Spring依赖注入的原理
```
// 1.通过反射调用Java.lang.Class
Productor productor = (Productor) Class.forName("com.quancheng.Productor").newInstance();
Productor productor = Productor.class.newInstance();
// 2.java.lang.reflect.Constructor类的newInstance()实例方法
Constructor<Productor> constructor = Productor.class.getConstructor();
Productor productor = constructor.newInstance();
```
##### clone\(\)方法
clone方法分为浅拷贝和深拷贝
* 浅拷贝:被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象。
* 深拷贝:不仅要复制对象的所有非引用成员变量值,还要为引用类型的成员变量创建新的实例,并且初始化为形式参数实例值。
浅拷贝的效果就是,对引用对象的操作,会影响到所有引用了该对象的对象
```
public class Object {
// clone方法定义
protected native Object clone() throws CloneNotSupportedException;
}
```
_注意:_
1. _Cloneable只是一个标志,想要使用super.clone\(\),则需要实现Cloneable接口,否则就会抛出CloneNotSupportedException异常;_
2. _clone\(\)实现的是浅复制,在重载clone方法的时候,需要转为深复制。即属性存在对象引用的时候,需要对引用属性再进行clone\(\)复制,直到没有对象引用;_
```
public class Appliction {
public static void main(String[] args) throws CloneNotSupportedException {
User user = new User();
user.setName("Tom");
user.setAge(20);
user.setWeight(120);
System.err.println(user);
User u = (User) user.clone();
System.err.println(u);
}
}
class User implements Cloneable {
private String name;
private int age;
private Integer weight;
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
......
}
```
##### 反序列化
序列化对象就是对象此刻在内存中的状态转成的字节码。通过实现Serializable接口进行序列化。同Cloneable一样,Serializable也是一个空接口,作为一个标志使用。通过ObjectStream的writeObject\(\)方法和readObject\(\)方法来序列化和反序列化
还有一个Externalizable接口同样可以实现序列化,Externalizable继承了Serializable,同时增加了writeExternal\(\)和readExternal\(\)两个方法,可以指定序列化哪些属性,对于需要隐藏的属性,在前面加上transient就可以。
_注意:序列化和反序列化是深复制,static、transient 后的变量无法序列化_
##### Unsafe
使用Unsafe"黑科技"实例化对象
```
public class Appliction {
private static Unsafe U;
public static void main(String[] args) throws InstantiationException {
User user = (User) U.allocateInstance(User.class);
user.setName("Tom");
System.err.println(user.getName());
}
static {
try {
Field theUnsafe = Unsafe.class.getDeclaredField("theUnsafe");
theUnsafe.setAccessible(true);
U = (Unsafe) theUnsafe.get("null");
} catch (NoSuchFieldException | IllegalAccessException e) {
e.printStackTrace();
}
}
}
class User implements Cloneable {
private String name;
private int age;
private Integer weight;
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
......
}
```
_注意:使用Unsafe方法实例化对象不会调用对象的构造方法_
- java演变
- JDK各个版本的新特性
- JDK1.5新特性
- JDK1.6新特性
- JDK1.7新特性
- JDK1.8新特性
- JAVA基础
- 面向对象特性
- 多态
- 方法重载
- 方法重写
- class
- 常量
- 访问修饰符
- 类加载路径
- java-equals
- 局部类
- java-hashCode
- Java类初始化顺序
- java-clone方法
- JAVA对象实例化的方法
- 基础部分
- JAVA基础特性
- JAVA关键字
- javabean
- static
- 日期相关
- final
- interface
- 函数式接口
- JAVA异常
- 异常屏蔽
- try-with-resource资源泄露
- JAVA引用
- WeakReference
- SoftReference
- PhantomReference
- 位运算符
- try-with-resource语法糖
- JDK冷知识
- JAVA包装类
- JAVA基本类型与包装类
- java.lang.Boolean
- java.lang.Integer
- java.lang.Byte
- java.lang.Short
- java.lang.Long
- java.lang.Float
- java.lang.Double
- java.lang.Character
- 日期相关
- TemporalAdjusters
- String
- 字符串常量池
- String拼接
- String编译期优化
- StringBuilder&StringBuffer
- intern
- 注解
- java标准注解
- 内置注解
- 元注解
- 自定义注解
- 注解处理器
- JVM注解
- Java8 Annotation新特性
- 反射-Reflective
- Reflection
- Class
- Constructor
- Method
- javabean-property
- MethodHandles
- 泛型
- 类型擦除
- bridge-method
- Accessor&Mutator方法
- enum
- JAVA数组
- finalize方法
- JAR文件
- JAVA高级编程
- CORBA
- JMX
- SPI
- Java SPI使用约定
- ServiceLoader
- 实际应用
- IO
- 工具类
- JDK常用工具类
- Objects
- System
- Optional
- Throwable
- Collections
- Array
- Arrays
- System
- Unsafe
- Number
- ClassLoader
- Runtime
- Object
- Comparator
- VarHandle
- 数据结构
- 栈-Stack
- 队列(Queue)
- Deque
- PriorityQueue
- BlockingQueue
- SynchronousQueue
- ArrayBlockingQueue
- LinkedBlockingQueue
- PriorityBlockingQueue
- ConcurrentLinkedQueue
- 列表
- 迭代器
- KV键值对数据类型
- HashMap
- TreeMap
- Hash冲突
- ConcurrentHashMap
- JDK1.7 ConcurrentHashMap结构
- jdk7&jdk8区别
- 集合
- Vector
- Stack
- HashSet
- TreeSet
- ArrayList
- LinkedList
- ArrayList && LinkedList相互转换
- 线程安全的集合类
- 集合类遍历性能
- 并发容器
- CopyOnWriteArrayList
- ConcurrentHashMap
- 同步容器
- BitMap
- BloomFilter
- SkipList
- 设计模式
- 设计模式六大原则
- 单例模式
- 代理模式
- 静态代理
- 动态代理
- JDK动态代理
- cglib动态代理
- spring aop
- 策略模式
- SpringAOP策略模式的运用
- 生产者消费者模式
- 迭代器模式
- 函数式编程
- 方法引用
- 性能问题
- Lambda
- Lambda类型检查
- Stream
- findFirst和findAny
- reduce
- 原始类型流特化
- 无限流
- 收集器
- 并行流
- AOP
- 静态织入
- aspect
- aspect的定义
- AspectJ与SpringAOP
- 动态织入
- 静态代理
- 动态代理
- JDK动态代理
- CGLib动态代理
- Spring AOP
- SpringAOP五种通知类型
- @Before
- @AfterReturning
- @AfterThrowing
- @After
- @Around
- Aspect优先级
- SpringAOP切点表达式
- within
- execution
- 嵌套调用
- 系统优化与重构
- 重叠构造器模式
- 工具类构造器优化
- 常见面试题
- new Object()到底占用几个字节
- 访问修饰符
- cloneable接口实现原理
- 异常分类以及处理机制
- wait和sleep的区别
- 数组在内存中如何分配
- 类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式
- 类的实例化顺序
- 附录
- JAVA术语
- FAQ
- 墨菲定律
- 康威定律
- 软件设计原则
- 阿姆达尔定律
- 字节码工具
- OSGI