1、访问修饰类this
公有访问修饰符-public:对全部类可见,使用对象:类、接口、变量、方法,类的全部公有方法和变量都能被子类继承。spa
public static voidmain(String[] args){//main方法必须使用public修饰,不然Java解释器不运行该类
}
受保护的访问修饰符-protected:子类和基类在同一包中:能被包中任何其余类访问;子类和基类不在同一包中:子类实例能够访问从基类继承过来的protected方法,而不能访问基类实例的protected方法。可修饰数据成员、构造方法、方法成员,不能修饰除了内部类的类;使用对象:变量、方法。线程
默认访问修饰符-default:在同一包内可见,不使用任何修饰符,使用对象:类、接口、变量、方法。code
//变量和方法的声明能够不使用任何修饰符
String version = "1.3.0";booleanprocessOrder(){return true;
}
私有访问修饰符-private:同一包内的类和全部子类可见,使用对象:变量、方法,不能修饰除了内部类的类;orm
public classLogger{//私有变量,其余类不能直接获得和设置该变量的值,要经过方法操做该变量
privateString format;publicString getFormat(){return this.format;
}//返回format的值
public voidsetFormat(String format){this.format =format;
}//设置format的值
}
2、非访问修饰类对象
static修饰符:修饰类方法、类变量,用来声明独立于对象的静态方法、静态变量(类变量),不管一个类实例化多少对象,它的静态变量只有一份拷贝。局部变量不能声明为static变量;静态方法不能使用类的非静态变量。blog
对类变量和类方法访问可以使用classname.variablename和classname.methodname继承
public classInstanceCounter{private static int numInstances = 0;//静态变量
protected static intgetCount(){returnnumInstances;
}//静态方法
private static voidaddInstance(){
numInstances++;
}
InstanceCounter(){
InstanceCounter.addInstance();
}public static voidmain(String[] args){
System.out.println(InstanceCounter.getCount());for(int i=0;i<500;++i){newInstanceCounter();
}
System.out.println(InstanceCounter.getCount());
}
}
运行结果:接口
0
500
final修饰符:修饰类、方法、变量,final修饰的类不能被继承,方法不能被继承类从新定义(便可被子类继承,不可被子类修改),变量为常量不可修改内存
abstract修饰符:建立抽象类和抽象方法
抽象类不能实例化对象,声明抽象类的惟一目的是为了未来对该类进行扩充,若是一个类包含抽象方法那么这个类必须是抽象类;可是抽象类能够不含抽象方法。
抽象方法是没有任何实现的方法,具体实现由子类提供;任何继承抽象类的子类要实现父类的全部抽象方法,除非子类也是抽象类。
public abstract classCaravan{privateString model;privateString year;public abstract void goFast();//抽象方法
}
class CaravanClass extends Caravan{
//实现抽象方法
void goFast(){
//……
}
}
synchronized修饰符:synchronized关键字声明的方法同一时间只能被同一线程访问
transient修饰符:序列化对象包含transient修饰的实例变量时,Java虚拟机(JVM)跳过该变量
public transient int limit = 33;//不会持久化
public int i;//持久化
volatile修饰符:volatile修饰的成员变量在每次线程访问时,都强制从共享内存中从新读取该变量的值。成员变量发生变化时,会强制线程将变化值写到共享内存,这样在两个不一样的线程会看到成员变量的同一个值
public class MyRunnable implementsRunnable{private volatile booleanactive;public voidrun(){
actiive= true;while(active){//①//……
}
}public voidstop(){
active= false;//②
}
}/**一般在一个线程调用run()方法,另外一个线程调用stop()方法,若是①中缓冲器的active值被使用,那么②的active值为false时循环不中止。
*可是实验volatile修饰active,因此 ②的active值为false时循环中止。*/