JAVA基础知识大全

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 called


3、关于构造方法
(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{}
}