1.封装类:对应8种基本数据类 Boolean Byte Short Integer Long Character Float Double
基本类和封装类的转换。封装类是只读而不能改写的。
class test{
public static void main(String[] args){
int i=3;
Integer in=new Integer(i); //基本-封装
int j=in.intValue(); //封装-基本,用Integer的inValue()方法
System.out.println("j="+j);
String s=in.toString(); //基本-字符类,用toString()
System.out.println("s="+s);
String str="123";
System.out.println(Integer.valueOf(str)); //字符-封装,注意这里valueOf()是静态方法,注意调用方法
}
}
2.CLASS类:当不知道对象的类类型时可以用等等。
获取的三种方式:
class test{
public static void main(String[] args){
point pt=new point();
Class c=pt.getClass(); //第一,getClass()方法
System.out.println(c.getName()); //getName获取类的名字
try{
Class c1=Class.forName("point"); //第二,(最常被使用的方法),forName("类名或者字符串等")方法
System.out.println(c1.getName());
}
catch(Exception e){
e.printStackTrace();
}
Class c2=point.class; //第三,类名.class后缀方法
System.out.println(c2.getName());
Class c3=int.class; //.class方法也适用基本数据类
System.out.println(c3.getName());
Class c4=Integer.TYPE; //基本数据类对应的封装类就要用.TYPE方法
System.out.println(c4.getName());
}
}
class point{
}
3.class point{
static{ //静态代码段,加载类的时候会执行这段代码
System.out.println("abc");
}
}
class line{
static{ //静态代码段,加载类的时候会执行这段代码
System.out.println("abc");
}
}
class test{
public static void main(String[] args){
new point(); //加载类
try{
Class.forName("line"); //通过class来加载类
}
catch(Exception e){
e.printStackTrace();
}
}
}
4.newInstance():调用缺省的构造方法。可以在不知道类名的时候去实例化一个对象。
class point{
void output{
System.out.println("abc");
}
}
class test{
public static void main(String[] args){
if(args!=1){
return;
}
try{
Class c=Class.forName("args[0]");
point pt=(point)c.newInstance(); //newInstance()是Object类型的,所以要转换
pt.output();
}
catch(Exception e){
e.printStackTrace();
}
}
}
这个例子用命令行的参数args[0]来传递,所以执行的时候要java test point,把point当参数传进来。
5.newInstance()是实现IOC、反射、面对接口编程和依赖倒置等技术方法的必然选择,new 只能实现具体类的实例化,不适合于接口编程。
6.关键字new和newInstance方法区别【转】
在初始化一个类,生成一个实例的时候,newInstance()方法和new关键字除了一个是方法,一个是关键字外,最主要有什么区别?它们的区别在于创建对象的方式不一样,前者是使用类加载机制,后者是创建一个新类。那么为什么会有两种创建对象方式?这主要考虑到软件的可伸缩、可扩展和可重用等软件设计思想。
Java中工厂模式经常使用newInstance()方法来创建对象,因此从为什么要使用工厂模式上可以找到具体答案。 例如:
class c = Class.forName(“Example”);
factory = (ExampleInterface)c.newInstance();
其中ExampleInterface是Example的接口,可以写成如下形式:
String className = "Example";
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
进一步可以写成如下形式:
String className = readfromXMlConfig;//从xml 配置文件中获得字符串
class c = Class.forName(className);
factory = (ExampleInterface)c.newInstance();
上面代码已经不存在Example的类名称,它的优点是,无论Example类怎么变化,上述代码不变,甚至可以更换Example的兄弟类Example2 , Example3 , Example4……,只要他们继承ExampleInterface就可以。
从JVM的角度看,我们使用关键字new创建一个类的时候,这个类可以没有被加载。但是使用newInstance()方法的时候,就必须保证:1、这个类已经加载;2、这个类已经连接了。而完成上面两个步骤的正是Class的静态方法forName()所完成的,这个静态方法调用了启动类加载器,即加载java API的那个加载器。
现在可以看出,newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。 这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。
最后用最简单的描述来区分new关键字和newInstance()方法的区别:
newInstance: 弱类型。低效率。只能调用无参构造。
new: 强类型。相对高效。能调用任何public构造。
7.Runtime类:提供了应用程序和环境的一个接口。它是一个单例模式。可以看jvm的内存和总的内存,可执行一个外部程序。
class runtime{
public static void main(String[] args){
Runtime r=Runtime.getRuntime();
System.out.println(r.freeMemory()); //用freeMemory()获取jvm内存
System.out.println(r.totalMemory()); //用totalMemory()获取总内存
try{
r.exec("notepad"); //这里执行了打开一个记事本的命令,exec是Runtime类的一个方法,用来执行一个外部程序或命令,它返回的是Proccess类
r.exec("javac p1234.java"); //执行命令javac p1234.java。这种方式可以应用到图形编写中。
}
catch(Exception e){
e.printStackTrace();
}
}
}