一、 java的類包
編寫好一個源程序后,首先要執行javac命令進行編譯源文件,並生成與源文件同名后綴為“.class”的字節碼文件(類文件),該類文件與源文件默認在同一個目錄中。該類文件是由用戶創建的,而在java編程環境中,java本身提供了大量的類文件,在編程時可以直接引入使用,極大方便了程序的編寫。
包的定義:是Java編程的基礎,包蘊涵於標准類的體系結構和用戶自己的程序中,包是有唯一命名的類的集合。在java中,包分為用戶包和系統包。
一)用戶包:即由用戶在項目中創建的包。
在命令提示符下,使用javac編譯程序時,將生成類文件,該文件默認與源文件在同一目錄下,如果一個項目很大,為了方便組織和管理,一般將不同的類組織起來進行管理,這就需要用戶自定義包
聲明創建包
package <包名1>.[<包名2>.[<包名3>..……]]
這里,包就是源程序根目錄下的文件夾名稱,但與window目錄結構表示法稍有不同的是,將window目錄中的斜杠“\”用實心點“.”來代替。
比如,HelloWorld.java源文件在C:\javaTest目錄里,為其源代碼聲明一個包,這個源程序代碼如下:
package lib.hello
public class HelloWorld
{
//程序的主函數入門
public staticvoid main(String args[])
{
//輸出打印字符語句
System.out.println("HelloWorld!");
}
}
程序的執行步驟:
1、在命令提示符下進入C:\javaTest,編譯源程序:javac HelloWorld.java,生成HelloWorld.class類文件。
2、在C:\javaTest目錄中新建lib文件夾,在lib文件夾中新建hello文件夾,將HelloWorld類文件剪切到hello文件夾。
3、運行源程序:java HelloWorld,輸出“HelloWorld!”字符。
創建包的規則:
1、 package語句必須放在源文件的最前面,其之前不可以有如何其它語句。
2、 每個源文件最多有一句package語句,因為一個類文件不可能屬於兩個包,
3、 一個包中可以包含多個包,其包含關系使用實心點“.”來表示。如語句“package lib.hello”,lib包中有包含hello包,其中lib包在程序(項目)根目錄下,要使用hello中的類文件,必須從程序(項目)根目錄中的包開始。
包機制引入的作用體現在以下幾個方面:
l 能夠實施訪問權限的控制。
l 利用包可以區分名字相同的類。在同一包中不允許出現同名類,不同包中可以存在同名類。
l 利用包可以對於不同的類文件划分和組織管理。
二)系統包
系統包指的就是java編程平台本身已經定義好的若干各類,Java為用戶提供了130多個預先定義好的包,引用過后再程序中就可以直接使用的類,下面做個簡要介紹:
1、java.lang包:java的核心類庫,包含了運行java程序必不可少的系統類,如基本數據類型、基本數學函數、字符串處理、線程、異常處理類等,系統缺省加載這個包
2、java.io包:java語言的標准輸入/輸出類庫,如基本輸入/輸出流、文件輸入/輸出、過濾輸入/輸出流等等
3、java.util包:包含如處理時間的date類,處理變成數組的Vector類,以及stack和HashTable類
4、java.awt包:構建圖形用戶界面(GUI)的類庫,低級繪圖操作Graphics類,圖形界面組件和布局管理如Checkbox類、Container類、LayoutManger接口等,以及界面用戶交互控制和事件響應,如Event類
5、java.awt.image包:處理和操縱來自於網上的圖片的java工具類庫
6、java.wat.peer包:很少在程序中直接用到,使得同一個java程序在不同的軟硬件平台上運行
7、java.applet包:包含所有實現JavaApplet的類。
8、java.net包:實現網絡功能的類庫有Socket類、ServerSocket類
9、java.corba包和java.corba.orb包
10、java.lang.reflect包:提供用於反射對象的工具
11、java.util.zip包:實現文件壓縮功能
12、java.awt.datatransfer包:處理數據傳輸的工具類,包括剪貼板,字符串發送器等
13、java.awt.event包
14、java.sql包:實現JDBC的類庫
15、java.rmi 提供遠程連接與載入的支持。
16、java.security 提供安全性方面的有關支持。
三)引用包
想要使用用戶建立的包,或者使用系統自帶的類包,方法如下:
方法一:直接使用包,即在要引用的類名前加上包名作為修飾符。一般用於在引用其它包中的類或接口的次數較少的情況下。
例如:lib.hello b = new lib.hello ( );
方法二:使用包引用語句import。
在java程序中,可以定義多條import語句。如果有package語句,則import語句緊接在其后,否則import語句應位於程序的第一條語句。使用import引入又有兩種如下寫法:
(1)import <包名>.<類名>
導入指定的一個public類或者接口。
(2)import 〈包名>.*
導入包中的當前類需要使用的所有類或接口,注意此時不能引用該包中其它文件夾中的類。這種方法一般不被推薦,因為它常導致程序加載許多不需要的類,增加了系統的負載,同時也加大了類名沖突的概率。因此一般建議使用第一種格式。
例如:
import lib.hello;
import lib.hello .*;
import java.io.*;
import jsit.util.Date;
二、 Java的訪問修飾符、修飾符
通過引用類包,可以實現對類的訪問控制。除此之外,java的訪問修飾符能夠精確控制類、類的變量、方法的訪問控制。
類:
訪問修飾符 修飾符 class 類名稱extends 父類名稱 implement 接口名稱1[,接口名稱2]……
(訪問修飾符與修飾符的位置可以互換)
| 訪問修飾符 |
||
| 名稱 |
說明 |
備注 |
| public |
可以被所有類訪問(使用) |
public類必須定義在和類名相同的同名文件中 |
| package |
可以被同一個包中的類訪問(使用) |
默認的訪問權限,可以省略此關鍵字,可以定義在和public類的同一個文件中 |
| private |
修飾內部類 |
|
| 修飾符 |
||
| 名稱 |
說明 |
備注 |
| 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 |
所有 |
|
| 無訪問修飾符(默認) |
同一個包內 |
|
