JAVA基础知识大全
1、对象的初始化
(1)非静态对象的初始化 在创建对象时,对象所在类的所有数据成员会首先进行初始化。 基本类型:int型,初始化为0。 如果为对象:这些对象会按顺序初始化。 ※在所有类成员初始化完成之后,才调用本类的构造方法创建对象。 构造方法的作用就是初始化。 (2)静态对象的初始化 程序中主类的静态变量会在main方法执行前初始化。 不仅第一次创建对象时,类中的所有静态变量都初始化,并且第一次访问某类(注意此时 未创建此类对象)的静态对象时,所有的静态变量也要按它们在类中的顺序初始化。 2、继承时,对象的初始化过程 (1)主类的超类由高到低按顺序初始化静态成员,无论静态成员是否为private。 (2)主类静态成员的初始化。 (3)主类的超类由高到低进行默认构造方法的调用。注意,在调用每一个超类的默认构造 方法前,先进行对此超类进行非静态对象的初始化。 (4)主类非静态成员的初始化。 (5)调用主类的构造方法。例如:
//父静态变量-->子静态变量-->父非静态变量-->父静态代码块-->父构造函数------>子非变量-->子静态代码块-->子构造函数
public class AA {
public static void main(String args[]) {
E bobj = new E();
System.out.println("-------------------------------"); D bo = new E();}
}
class D {
int i = ff(); static String yy = out(); D() {System.out.println("D.D called");
}
int ff() {System.out.println("D.ff called");
return 47;
}
static String out (){
System.out.println("D.out called"); return "47"; } }class E extends D {
int i = f();
static String yy = out(); int j;{
j = 37;
System.out.println("initialization block executed");
}
E() {
System.out.println("E.E called");
}
final int f() {
System.out.println("E.f called");
return 47;
}
static String out (){
System.out.println("E.out called"); return "47"; } }结果:
D.out called
E.out called D.ff called D.D called E.f called initialization block executed E.E called ------------------------------- D.ff called D.D called E.f called initialization block executed E.E called3、关于构造方法 (1)类可以没有构造方法,但如果有多个构造方法,就应该要有默认的构造方法,否则在继承此类时,需要在子类中显式调用父类的某一个非默认的构造方法了。 (2)在一个构造方法中,只能调用一次其他的构造方法,并且调用构造方法的语句必须是 第一条语句。 4、有关public、private和protected (1)无public修饰的类,可以被其他类访问的条件是:a.两个类在同一文件中,b.两个类 在同一文件夹中,c.两个类在同一软件包中。 (2)protected:继承类和同一软件包的类可访问。 (3)如果构造方法为private,那么在其他类中不能创建该类的对象。 5、抽象类 (1)抽象类不能创建对象。 (2)如果一个类中一个方法为抽象方法,则这个类必须为abstract抽象类。 (3)继承抽象类的类在类中必须实现抽象类中的抽象方法。 (4)抽象类中可以有抽象方法,也可有非抽象方法。抽象方法不能为private。 (5)间接继承抽象类的类可以不给出抽象方法的定义。 6、final关键字 (1)一个对象是常量,不代表不能转变对象的成员,仍可以其成员进行操作。 (2)常量在使用前必须赋值,但除了在声明的同时初始化外,就只能在构造方法中初始化 。 (3)final修饰的方法不能被重置(在子类中不能出现同名方法)。 (4)如果声明一个类为final,则所有的方法均为final,无论其是否被final修饰,但数据 成员可为final也可不是。 7、接口interface(用implements来实现接口) (1)接口中的所有数据均为static和final即静态常量。尽管可以不用这两个关键字修饰 ,但必须给常量赋初值。 (2)接口中的方法均为public,在实现接口类中,实现方法必须可public关键字。 (3)如果使用public来修饰接口,则接口必须与文件名相同。 8、多重继承 (1)一个类继承了一个类和接口,那么必须将类写在前面,接口写在后面,接口之间用逗 号分隔。 (2)接口之间可多重继承,注意使用关键字extends。 (3)一个类虽只实现了一个接口,但不仅要实现这个接口的所有方法,还要实现这个接口 继承的接口的方法,接口中的所有方法均须在类中实现。 9、接口的嵌入 (1)接口嵌入类中,可以使用private修饰。此时,接口只能在所在的类中实现,其他类不 能访问。 (2)嵌入接口中的接口一定要为public。 10、类的嵌入 (1)类可以嵌入另一个类中,但不能嵌入接口中。 (2)在静态方法或其他方法中,不能直接创建内部类对象,需通过手段来取得。 手段有两种: classA{ classB{} BgetB(){ Bb=newB(); returnb; } } staticvoidm(){ Aa=newA(); A.Bab=a.getB();//或者是A.Bab=a.newB(); } (3)一个类继承了另一个类的内部类,因为超类是内部类,而内部类的构造方法不能自动 被调用,这样就需要在子类的构造方法中明确的调用超类的构造方法。 接上例: classCextendsA.B{ C(){ newA().super();//这一句就实现了对内部类构造方法的调用。 } } 构造方法也可这样写: C(Aa){ a.super(); }//使用这个构造方法创建对象,要写成Cc=newC(a);a是A的对象。 11、异常类 JAVA中除了RunTimeException类,其他异常均须捕获或抛出。
JAVA之各类修饰子
1. 顶级类的修饰子: 默认 ; public ; final ; abstract .
默认时,称为frends的,不能跨包访问.
2. 顶级接口的修饰子: 默认 ; public ; abstract .
默认时, 称为frends的,不能跨包访问
3. 嵌套类的修饰子: //////////////默认; final ; abstract . static
嵌套在类中的类:
在方法内的类:
不在方法中的类:
嵌套在接口中的类:不能嵌套。
4 . 嵌套接口的修饰子: /////////// 默认; abstract
嵌套在类中的接口:
在方法内的接口:
不在方法中的接口:
嵌套在接口中的接口:
注意: 内部类和匿名类区分
5. 成员变量的修饰子: public ; protected ; 默认; private; static ; final ; transient ; volatile
6. 方法的修饰子: public ; protected ; 默认; private; static ; final ; abstract; synchronized
abstract说明: ……
注意: final 和 abstract 任何时候不能同时使用.
其实接口和类很相似,都是不能为private和protected
但是都有例外的时候,就是inner class和inner interface
class A
{
protectedinterface B
{void f();}
}
class B
{
protectedclass C
{}
}
interface默认是friendly
想变成public的时候才加public
那就是说friendly也可以了,可为什么protected就不行呢?
1.如果一个顶级类或顶级接口定义为PUBLIC时类名必须和类名相同,如果是默认或其他时的可以不相同。
2.一个文件里只能有一个PUBLIC的类和接口
public接口确实要和文件同名,没错
但是只用main()所在的类可以定义为public好象不怎么对吧
看下面的代码
publicclass A
{
publicstaticvoid f()
{System.out.println("This is A");}
}
class B
{
publicstaticvoid main(String args[])
{A.f();}
}
可以编译执行
(编译是能通过,不过运行不了的,运行显示有异常没主方法)这句话是不对的巴
运行结果:
This is A
public class S {
public static void f() {
System.out.println("This is A");
}
public void ff() {
System.out.println("This is A");
}
}
class B {
public static void main(String args[]) {
S.f();
}
public void bb() {
}
}
public class Z {
public void get(){
S a = new S();
B b = new B();
a.ff();
b.bb();
}
}
2.
class S {
public static void f() {
System.out.println("This is A");
}
public void ff() {
System.out.println("This is A");
}
}
class B {
public static void main(String args[]) {
S.f();
}
public void bb() {
}
}
在IDE中是可以的。在JDK命令行中没有试验。
4.
interface Z{
final int i=0;
static int ii=0;
public final static int iii=0;
}
class Bimplements Z{
public static void main(String args[]) {
B b=new B();
int a=b.i;
int aa=B.i;
int aaa=B.ii;
int aaaa=B.iii;
}
public void bb() {
}
}
接口中的方法是抽象的不能用{ }
要用分号结束(public void get();)
public class Demo {
public void get()throws IOException, SQLException{
System.out.println("Demo");
}
}
abstract class m extends Demo{
//覆盖了父类的方法,并且抽象化了这个方法。也是可以的
public abstract void get();//默认是顶层Exception异常
}
class mm extends Demo{
public void get()throws SQLException{}
}