java修饰类_Java修饰类

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时循环中止。*/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值