JAVA修饰符类型(public,protected,private,friendly)

转自:http://www.cnblogs.com/webapplee/p/3771708.html

JAVA修饰符类型(public,protected,private,friendly)

public的类、类属变量及方法,包内及包外的任何类均可以访问;
protected的类、类属变量及方法,包内的任何类,及包外的那些继承了此类的子类才能访问;
private的类、类属变量及方法,包内包外的任何类均不能访问;
如果一个类、类属变量及方法不以这三种修饰符来修饰,它就是friendly类型的,那么包内的任何类都可以访问它,而包外的任何类都不能访问它(包括包外继承了此类的子类),因此,这种类、类属变量及方法对包内的其他类是友好的,开放的,而对包外的其他类是关闭的。

类:
访问修饰符 修饰符 class 类名称 extends 父类名称 implement 接口名称
(访问修饰符与修饰符的位置可以互换)
访问修饰符
名称 说明 备注
public 可以被所有类访问(使用) public类必须定义在和类名相同的同名文件中
package 可以被同一个包中的类访问(使用) 默认的访问权限,可以省略此关键字,可以定义在和public类的同一个文件中
 
修饰符
名称 说明 备注
final 使用此修饰符的类不能够被继承  
abstract 如果要使用abstract类,之前必须首先建一个继承abstract类的新类,新类中实现abstract类中的抽象方法。 类只要有一个abstract方法,类就必须定义为abstract,但abstract类不一定非要保护abstract方法不可
     
 
变量
l         Java中没有全局变量,只有方法变量、实例变量(类中的非静态变量)、类变量(类中的静态变量)。
l         方法中的变量不能够有访问修饰符。所以下面访问修饰符表仅针对于在类中定义的变量。
l         声明实例变量时,如果没有赋初值,将被初始化为null(引用类型)或者0、false(原始类型)。
l         可以通过实例变量初始化器来初始化较复杂的实例变量,实例变量初始化器是一个用{}包含的语句块,在类的构造器被调用时运行,运行于父类构造器之后,构造器之前。
l         类变量(静态变量)也可以通过类变量初始化器来进行初始化,类变量初始化器是一个用static{}包含的语句块,只可能被初始化一次。
访问修饰符
名称 说明 备注
public 可以被任何类访问  
protected
可以被同一包中的所有类访问
可以被所有子类访问
子类没有在同一包中也可以访问
private 只能够被当前类的方法访问  
缺省
无访问修饰符
可以被同一包中的所有类访问 如果子类没有在同一个包中,也不能访问
 
修饰符
名称 说明 备注
static 静态变量(又称为类变量,其它的称为实例变量)
可以被类的所有实例共享。
并不需要创建类的实例就可以访问静态变量
final 常量,值只能够分配一次,不能更改
注意不要使用const,虽然它和C、C++中的const关键字含义一样
可以同static一起使用,避免对类的每个实例维护一个拷贝
transient 告诉编译器,在类对象序列化的时候,此变量不需要持久保存 主要是因为改变量可以通过其它变量来得到,使用它是为了性能的问题
volatile 指出可能有多个线程修改此变量,要求编译器优化以保证对此变量的修改能够被正确的处理  
 
方法
访问修饰符 修饰符 返回类型 方法名称(参数列表throws 违例列表
l         类的构造器方法不能够有修饰符、返回类型和throws子句
l         类的构造器方法被调用时,它首先调用父类的构造器方法,然后运行实例变量和静态变量的初始化器,然后才运行构造器本身。
l         如果构造器方法没有显示的调用一个父类的构造器,那么编译器会自动为它加上一个默认的super(),而如果父类又没有默认的无参数构造器,编译器就会报错。super必须是构造器方法的第一个子句。
l         注意理解private构造器方法的使用技巧。
访问修饰符
名称 说明 备注
public 可以从所有类访问  
protected
可以被同一包中的所有类访问
可以被所有子类访问
子类没有在同一包中也可以访问
private 只能够被当前类的方法访问  
缺省
无访问修饰符
可以被同一包中的所有类访问 如果子类没有在同一个包中,也不能访问
 
修饰符
名称 说明 备注
static 静态方法(又称为类方法,其它的称为实例方法)
提供不依赖于类实例的服务
并不需要创建类的实例就可以访问静态方法
final 防止任何子类重载该方法
注意不要使用const,虽然它和C、C++中的const关键字含义一样
可以同static一起使用,避免对类的每个实例维护一个拷贝
abstract 抽象方法,类中已声明而没有实现的方法 不能将static方法、final方法或者类的构造器方法声明为abstract
native 用该修饰符定义的方法在类中没有实现,而大多数情况下该方法的实现是用C、C++编写的。 参见Sun的Java Native接口(JNI),JNI提供了运行时加载一个native方法的实现,并将其于一个Java类关联的功能
synchronized 多线程的支持 当一个此方法被调用时,没有其它线程能够调用该方法,其它的synchronized方法也不能调用该方法,直到该方法返回
 
接口
访问修饰符 interface 接口名称 extends 接口列表
l         接口不能够定义其声明的方法的任何实现
l         接口中的变量总是需要定义为“public static final 接口名称”,但可以不包含这些修饰符,编译器默认就是这样,显示的包含修饰符主要是为了程序清晰
访问修饰符
名称 说明 备注
public 所有  
无访问修饰符(默认) 同一个包内  
 
package com.fn.pa;
public class A {
protected int a=0;                      //这里可以将protected改为private,public以及空来进行测试;
public static void main(String[] args) {
A a=new A();
System.out.println(a.a);
}
}

package com.fn.pa;
import com.fn.pb.C;
public class B extends A {
void f(){
a=11;
}
public static void main(String[] args) {
B b=new B();
A a=new A();
C c=new C();
System.out.println(c.a);
System.out.println(a.a);
System.out.println(b.a);
}
}

package com.fn.pa;
public class D {
public static void main(String[] args) {
// TODO Auto-generated method stub
A a=new A();
a.a=11;
System.out.println(a.a);
}
}

package com.fn.pb;
import com.fn.pa.*;
public class C extends A {
void f()
{
a=10;
}
public static void main(String[] args) {
C c = new C();
A a=new A();
B b=new B();
System.out.println(a.a);             //不可见的,出错
System.out.println(c.a);
System.out.println(b.a);           //不可见的,出错
}
}

package com.fn.pb;

import com.fn.pa.A;

public class E {
public static void main(String[] args) {
A a=new A();
System.out.println(a.a);    //不可见的,出错
}
}

总结:
public: 所有类都可访问;
private: 只有已类才可访问;
protected:
子类:成员方法中都能访问(不管同包还是不同包);
friendly:
同包可访问,不同包不能访问;

上一篇:php public protected private属性实例详解


下一篇:使用GDB调试程序反汇编方法