客戶端程序員:即在其應用中使用數據類型的類消費者,他的目標是收集各種用來實現快速應用開發的類。
類創建者:即創建新數據類型的程序員,目標是構建類。
訪問控制存在的原因:a、讓客戶端程序員無法觸及他們不應該觸及的部分 ; b、允許庫設計者可以改變類內部的工作方式而不用擔心會影響到客戶端程序員
java的四個關鍵字:public、protected、default、private(他們決定了緊跟其後被定義的東西可以被誰使用)
適用范圍<訪問權限范圍越小,安全性越高>
訪問權限 類 包 子類 其他包
public ∨ ∨ ∨ ∨ (對任何人都是可用的)
protect ∨ ∨ ∨ × (繼承的類可以訪問以及和private一樣的權限)
default ∨ ∨ × × (包訪問權限,即在整個包內均可被訪問)
private ∨ × × × (除類型創建者和類型的內部方法之外的任何人都不能訪問的元素)
以下,用代碼進行詳解(建四個類 Person Student Teacher Parents 和一個測試類)
package com.zq.demo.test1;
/**
* 類內
* @author Administrator
*/
public class Person {
public String uname = "王五";
public void introduceMyself(){
System.out.println(uname);
}
}
package com.zq.demo.test1;
//同一個包
public class Student {
Person p = new Person();
public void test(){
System.out.println(p.uname);
}
}
package com.zq.demo.test1;
//子類
public class Teacher extends Person{
public int age;
Person p = new Person();
public void test1(){
System.out.println(p.uname);
}
}
package com.zq.demo.test2;
//不同包
import com.zq.demo.test1.Person;
public class Parents {
public String uname = "haha";
Person p = new Person();
public void test2(){
System.out.println(p.uname);
}
}
測試類的結果 顯示public在上述均能訪問到
用同樣的四個類 來測試protected
在將Person中的uanme改為protected後 類Parents便報錯了 The field Person.uname is not visible (說明不能跨包)
其他三個無影響
說明除了跨包 其他均不影響訪問
private
只有本類中可以訪問 但是借助在Person類中有關uname的set、get方法便可以進行訪問
default
測試結果說明 只能在本包中進行訪問 在其他包 即使是繼承關系 也無法進行訪問