1.
对于类中的final类型属性,一般在声明的时候直接写 final int a =1 ;但也可以在构造函数中进行赋值
如:
final int a;
A{}( a =1;)
但要注意:需要每一个构造函数都赋值,且不能嵌套。
而:如果想写static final int a;则必须在声明时进行初始化,static final int a = 1;因为静态的也是不属于类。
2.
继承中要注意的问题:子类对父类中构造方法的问题
父类的中构造方法不能被继承,故
class A{}
class B extends A{ A();} //是错的,只能用super关键字
如果子类中没有显示的调用super,则系统会加上,super();注意即是找父类中无参数的构造方法,所以,如果父类自己写了构造方法而导致无参数的已经不存在了,
则会出错.
3.
静态方法:只属于类本身,而不是某个对象。它是在类加载的时候,就已经为之分配好内存了。这时,并没有产生这个的对象。而对象只有在new时候才会出现。所以只能把这个变量加个static.这也叫做类变量,与之对应的叫做实例变量。
4.
main是静态的,因为它不是属于某个类的,而是全局的。
因此在执行时直接找到main,而不是针对某个类的对象。
如果不是static,则会先产生类的对象。
public:由于其是虚拟机调用,因此必须是public的
static:由于其不必产生对象,因此是static的
5.
对于主类的修饰符是default时:表示在同一个包中可以被访问。
6.
final类不能被继承。
7.
private的方法,只要出了类就不能被访问,不管是在同一个包中,还是继承关系。
默认的访问权限都是在这个包中,被继承也不能被访问。
protected 方法对以上均适用,但 和 public 方法也有区别
在于:对于不同包中,没有继承关系的两个类而言,在一个类中使用了另一个类的对象,则只有public方法可以被访问,而protected方法不能被访问。
8.
抽象方法的声明:abstract void proMethod(); //不要加大括号
看一个类是否被实现,不是看{}里面有没有代码,而是看有没有{}
9. JNI(Java Native Interface),它允许Java虚拟机(JVM)内部运行的Java代码能够与用其它编程语言(如c、c++、汇编语言)编写的应用程序和库进行互操作。
JNI可以理解为Java和本地应用程序之间的中介。
它最大的好处是没有对底层Java虚拟机的实现施加任何限制。
写一个native的方法:
1.写java代码段,如HelloWorld.java。
2.用javac来编译之,得到.class文件。
3.用javah -jni 来生成HelloWorld头文件,得到HelloWorld.h
4.用HelloWorld.h来生成本地方法,得到HelloWorldImp.c
5.编译本地代码,加载共享库,生成Hello.so
(so文件是linux,或unix下动态连接库的文件,相当于windows下的.dll)
10.
对于接口中的方法,默认情况下就是public abstract的,因此不用再写,也因此,实现接口时必须用public来修饰。
接口中的数据成员默认都是public static final.
11.
以下是代码片段:
class Z extends A implements B,C
{
}
//注意这个顺序先派生类,再实现接口。
12.
有关内部类:
当我们产生一个派生类的对象的时候,它会调用基类的构造函数,产生一个基类的对象。
因此
以下是代码片段:
class Car
{
class Wheel
{
}
}
class PlaneWheel extends Car.Wheel
{
public static void main(String[] args)
{
PlaneWheel pw = new PlaneWheel();
}
}
这是不能通过编译的,因为我们要产生pw,就必须先产生Car.Wheel的对象,而它是内部类,所以要产生它的对象,就必须先产生外部类的对象,才能建立起内部与外部的引用关系。
因此作出改变:
以下是代码片段:
class PlaneWheel extends Car.Wheel
{
PlaneWheel(Car car)
{
car.super();
}
public static void main(String[] args)
{
Car car = new Car();
PlaneWheel pw = new PlaneWheel(car);
}
}
21.
javac A.java
可以生成B.class
前提是classB,在A.java中被声明为一个类,且不是Public的。
22.
finally的问题:不是在try,catch之后的语句就相当于finally,因为如果在try中有return语句,则其后的是不会被执行的。而如果放在finally中,则一定会执行。
如果在代码中会有一个严重错误,而不想让finally中的语句执行,则写
System.exit(-1);来避免其执行。//不是0就可以。
23.
c++中允许程序员重载操作符,但java中不允许。
针对String的"+"和"+=",是java中唯一被重载的操作符。
24.
StringBuffer的应用:
StringBuffer sb = new StringBuffer().append("a").append("bc").append("123");
可用toString()方法,将其转化为toString();
由于在打印时会自动调用toString方法,因此,打印时不必显示加上。
25.
java中的索引是从0开始,而且,对于一个区间的数值,是大于等于,小于的关系。即前面的数字是包含的,而后面的是不包含的。
26.
java中,传参时:
对于基本数据类型,传递的是数据的拷贝;
对于引用类型,传递的引用的拷贝。但是对于引用的拷贝,是浅拷贝,即指向了堆中同一处内存。
因此在改变值的时结果不一样,对于基本类型,其回到传参者时没有改变其值,而对于引用,其值则改变了。
27.
有的接口中没有任何抽象方法,如cloneable,叫作标识接口。它仅仅是告诉编译器自己可以被克隆。
如果类中的成员有引用,则涉及到浅拷贝还是深拷贝的问题。
浅拷贝就是把除了引用成员的全都拷贝一份,而对于引用部分则指向同一处。而深拷贝就是把所有的都拷贝一份。
调用super.clone()方法,它可以在运行时刻,object中的clone()识别出你要复制的哪一个对象,然后为此对象分配空间,并进行对象复制,将原始对象的内容一一复制到新对象的存储空间中。
28.
Integer的
valueOf(String s) //把s转化成一个包装类对象返回
parseInt(String s) //把s转化成一个int型数据返回
封装类的对象的值是不能被修改的,只能是读。
29.
java中,每个class都有一个相应的Class对象。也就是说,当我们编写一个类,编译完成后,在生成的.class文件中,就会产生一个Class对象,用于表示这个类的类型信息。
获取class实例的三种方式:
a.利用对象调用getClass()方法获取该对象的class实例;
b.使用class类的静态方法forName(),用类的名字获取一个class实例
c.运用.class的方式来获取class实例,对于基本数据类型的封装类,还可以用.type来获取相对应的基本数据类型的class类型。
如:
以下是代码片段:
Point pt = new Point();
Class c1 = pt.getClass();
System.out.println(c1.getName());
try{
Class c2 = Class.forName("Point");
System.out.println(c2.getName());
}
catch{……}
Class c3 = Point.class;
System.out.println(c3.getName());
Class c4 = int.class;
System.out.println(c4.getName());
Class c5 = Integer.TYPE;
System.out.println(c5.getName());
30.
java中的反射api:主要用于:对于某个不知道名字的类,通过反射机制调用他们的构造函数,为构造函数及其他函数进行传参,调用。
31.
runtime这个类提供了应用程序与环境之间的接口。
可以获取jvm的总共内存,已占有的内存。
用getRuntime()方法获取其实例。
Runtime rt = Runtime.getRuntime();
System.out.println(rt.freeMemory());
System.out.println(rt.totalMemory());
另可以有执行命令,返回一个process. 为应用程序做准备。
try{rt.exec("notepad");}
try{rt.exec(javac ArrayTest.java);};
要获得其具体输出的信息,可以用process类。
try{
Process p = rt.exec("java ArrayTest");
InputStream is = p.getInputStream();//此时,其输出全在了 InputStream中
int data;
while((data=is.read())!=-1)
{
System.out.print((char)data);
}
}
Runtime类是使用单例模式的一个例子。
32.
单例模式:
a.一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类。
b.单例类的一个最重要特点:它是类的构造方法是私有的,从而避免了外部利用构造方法直接创建多个实例。
以下是代码片段:
class Singleton
{
private static final Singleton st = new Singleton();
private Singleton(){}
public static Singleton getInstance()
{
return st;
}
}