Java修饰类

1、访问修饰类this

公有访问修饰符-public:对全部类可见,使用对象:类、接口、变量、方法,类的全部公有方法和变量都能被子类继承。spa

public static void main(String[] args){ //main方法必须使用public修饰,不然Java解释器不运行该类
}

 

受保护的访问修饰符-protected:子类和基类在同一包中:能被包中任何其余类访问;子类和基类不在同一包中:子类实例能够访问从基类继承过来的protected方法,而不能访问基类实例的protected方法。可修饰数据成员、构造方法、方法成员,不能修饰除了内部类的类;使用对象:变量、方法。线程

默认访问修饰符-default:在同一包内可见,不使用任何修饰符,使用对象:类、接口、变量、方法。code

//变量和方法的声明能够不使用任何修饰符
String version = "1.3.0"; boolean processOrder(){ return  true; }

私有访问修饰符-private:同一包内的类和全部子类可见,使用对象:变量、方法,不能修饰除了内部类的类;orm

public class Logger{ //私有变量,其余类不能直接获得和设置该变量的值,要经过方法操做该变量
    private String format; public String getFormat(){ return this.format; }//返回format的值

    public void setFormat(String format){ this.format = format; }//设置format的值
}

 

 

2、非访问修饰类对象

static修饰符:修饰类方法、类变量,用来声明独立于对象的静态方法、静态变量(类变量),不管一个类实例化多少对象,它的静态变量只有一份拷贝。局部变量不能声明为static变量;静态方法不能使用类的非静态变量。blog

对类变量和类方法访问可以使用classname.variablename和classname.methodname继承

public class InstanceCounter{ private static int numInstances = 0;//静态变量

    protected static int getCount(){ return numInstances; }//静态方法

    private static void addInstance(){ numInstances++; } InstanceCounter(){ InstanceCounter.addInstance(); } public static void main(String[] args){ System.out.println(InstanceCounter.getCount()); for(int i=0;i<500;++i){ new InstanceCounter(); } System.out.println(InstanceCounter.getCount()); } }

运行结果:接口

0
500

 

final修饰符:修饰类、方法、变量,final修饰的类不能被继承,方法不能被继承类从新定义(便可被子类继承,不可被子类修改),变量为常量不可修改内存

 

abstract修饰符:建立抽象类和抽象方法

抽象类不能实例化对象,声明抽象类的惟一目的是为了未来对该类进行扩充,若是一个类包含抽象方法那么这个类必须是抽象类;可是抽象类能够不含抽象方法。

抽象方法是没有任何实现的方法,具体实现由子类提供;任何继承抽象类的子类要实现父类的全部抽象方法,除非子类也是抽象类。

public abstract class Caravan{ private String model; private String 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 implements Runnable{ private volatile boolean active; public void run(){ actiive = true; while(active){////……
 } } public void stop(){ active = false;//
 } } /* *一般在一个线程调用run()方法,另外一个线程调用stop()方法,若是①中缓冲器的active值被使用,那么②的active值为false时循环不中止。 *可是实验volatile修饰active,因此 ②的active值为false时循环中止。 */
相关文章
相关标签/搜索