1. java的实例化
对象是类的一个实例,创建对象的过程也叫类的实例化。对象是以类为模板来创建的。
在Java中,使用new关键字来创建对象,一般有以下三个步骤:
声明:声明一个对象,包括对象名称和对象类型
实例化:使用关键字new来创建一个对象。
初始化:使用new创建对象时,会调用构造方法初始化对象。
2. Java实例化的几种方式
1、用new语句创建对象,这是最常见的创建对象的方法。
2、通过工厂方法返回对象,如:String str = String.valueOf(23);
3、运用反射手段,调用java.lang.Class或者java.lang.reflect.Constructor类的newInstance()实例方法。如:Object obj = Class.forName("java.lang.Object").newInstance();
4、调用对象的clone()方法。
5、通过I/O流(包括反序列化),如运用反序列化手段,调用java.io.ObjectInputStream对象的 readObject()方法。
3. Java中什么叫实例化
把一个类,变成实际存在的一个"例子",叫实例化.
说白了,如:
"人"是一个概念,相当于一个"类"
"小明"是一个具体存在的"人"的例子,相当于一个"实例".
把"人"变成"小明"的过程,就是"人的实例化".
4. java涓瀹炰緥鍖栨槸浠涔堟剰镐
瀹炰緥鍖栨槸鎸囧湪缂栫▼涓鍒涘缓涓涓瀵硅薄镄勮繃绋嬨傚湪Java璇瑷涓锛屾垜浠浣跨敤鍏抽敭瀛椻渘ew钬濇潵瀹炰緥鍖栦竴涓瀵硅薄銆傝繖涓杩囩▼鍖呮嫭涓哄硅薄鍒嗛厤鍐呭瓨绌洪棿銆佽皟鐢ㄥ硅薄镄勬瀯阃犳柟娉曡繘琛屽埯濮嫔寲绛変竴绯诲垪镎崭綔銆傞氲繃瀹炰緥鍖栧彲浠ュ湪绋嫔簭涓浣跨敤瀵硅薄镄勫睘镐у拰鏂规硶锛屼互瀹屾垚钖勭嶅姛鑳姐
瀹炰緥鍖栬繃绋嬩竴鑸鍒嗕负浠ヤ笅锲涙ワ细绗涓姝ユ槸澹版槑瀵硅薄绫诲瀷锛屽嵆锻婅瘔绋嫔簭鎴戜滑闇瑕佸垱寤虹殑瀵硅薄绫诲瀷鏄浠涔堬绂绗浜屾ユ槸浣跨敤鍏抽敭瀛椻渘ew钬濆垱寤哄硅薄锛涚涓夋ユ槸璋幂敤瀵硅薄镄勬瀯阃犳柟娉曡繘琛屽埯濮嫔寲锛涙渶钖庝竴姝ユ槸灏嗗硅薄镄勫紩鐢ㄤ缭瀛桦埌鍙橀噺涓锛屼互渚垮湪绋嫔簭涓浣跨敤銆
鍦↗ava涓锛屾疮涓绫婚兘鍙浠ヨ瀹炰緥鍖栵纴涔熷彲浠ュ疄渚嫔寲澶氢釜瀵硅薄銆傝繖浜涘硅薄镄勫睘镐у拰鏂规硶鍦ㄤ笉钖岀殑瀹炰緥涓鏄镫绔嬬殑锛屽畠浠涔嬮棿涓崭细鐩镐簰褰卞搷銆傚疄渚嫔寲鍙浠ヨ╂垜浠鍦ㄤ竴涓绫荤殑锘虹涓婂垱寤哄嚭澶氢釜鍏锋湁涓嶅悓灞炴у拰鏂规硶镄勫硅薄锛岃繖镙峰氨鍙浠ュ湪涓嶅悓镄勫満鏅涓浣跨敤涓嶅悓镄勫疄渚嬨
5. java实例化
后两种方法是静态工厂方法。它们和new语句的区别如下:
我们要得到一个对象,马上想到构造方法(new语句调用构造方法),其实,静态工厂方法也可以替我们做到。
例如,在jdk1.4里面,Boolean用了一个静态方法来得到一个boolean对象:
public static Boolean valueOf(boolean b)
question:这个方法实际上并不返回一个object?
对的, sun的jdk 帮助里面讲: If a new Boolean instance is not required, this method should generally be used in preference to the constrUCtor Boolean(boolean).
但是,不是说静态工厂方法所有时候都不返回一个object,只是不是所有时候都返回一个object。
使用静态工厂方法和构造方法比较的优缺点:
优点:
1. 静态工厂方法都是有自己的名字,轻易理解.
2. 静态工厂方法并不要求每次都生成一个对象.比如上面提到的Boolean的public static Boolean valueOf(boolean b)就不会返回一个object. sun的jdk帮助文档里面也提到,在不需要得到一个对象的情况下,使用valueof方法可以得到性能的提升.
而且这样,可以控制类在生的期间该类的句柄数,这个作用在单态(item 21)和类型安全(item 21)都是有用的.
3. 静态工厂方法可以返回该类的任何子类,这给了程序员更大的选择空间.
比如Collections,用了很多静态工厂方法来得到immuable的set,map之类的.
而且静态工厂方法可以强迫user通过接口来引用被返回的对象,而不是每次都使用构造函数,这是一个好习惯.
静态工厂方法返回的类,在编写含有静态工厂方法这个类的时候,可以并不存在,这就提供了一种灵活的service provider framework.比如Java的密码系统扩展(JCE),provider为user提供多个api实现,framework提供一种机制来register这些实现,用户只需直接使用api,而不用考虑自己在使用哪个实现。
下面是这种机制的程序框架:
import java.util.*;
// Provider framework sketch
public abstract class Foo {
// Maps String key to corresponding Class object
private static Map implementations = null;
// Initializes implementations map the first time it´s called
private static synchronized void initMapIfNecessary() {
if (implementations == null) {
implementations = new HashMap();
// Load implementation class names and keys from
// Properties file, translate names into Class
// objects using Class.forName and store mappings.
// ...
}
}
public static Foo getInstance(String key) {
initMapIfNecessary();
Class c = (Class) implementations.get(key);
if (c == null)
return new DefaultFoo();
try {
return (Foo) c.newInstance();
} catch (Exception e) {
return new DefaultFoo();
}
}
public static void main(String[] args) {
System.out.println(getInstance("NonexistentFoo"));
}
}
class DefaultFoo extends Foo {
}
静态工厂方法的缺点:
1. 仅仅有静态工厂方法而没有public的构造方法的类不能被继续…这也不是没有好处--可能能迫使程序员使用复合来代替继续.
2. 有时候可能会导致与其他的static方法混淆.这个缺点可以通过使用标准的命名方法来区别于其他的static方法.
现在有两种方法已经开始形成标准:
valueof(type k)-返回和k有相同值的句柄.
Getinstance-返回一个复合参数所描述的句柄.但是不一定和参数具有相同的值..这个方法在Provider framework里面是很有用的.
所以,我们不要每次都毫不犹豫的使用构造方法,有时候静态工厂方法可能是更加合适的.但是当你无法取舍的时候,还是使用构造方法吧,因为它是比较普通和标准的.
文章来源: 动态网站制作(www.knowsky.com) 出处:http://www.knowsky.com/369377.html