當前位置:才華齋>計算機>java語言>

JavaWeb基礎教程之Java基礎加強版參考

java語言 閱讀(1.46W)

1、myeclipse的安裝和使用

JavaWeb基礎教程之Java基礎加強版參考

* eclipse:是一個免費的開發工具* myeclipse:是一個收費的外掛,破解myeclipse,** 安裝目錄的要求: 不能有中文和空格** 安裝完成之後,選擇一個工作空間 ,這個工作空間不能有中文和空格* 破解myeclipse** 執行檔案,但是執行之前,必須要安裝jdk,通過配置環境變數* myeclipse的使用* 建立一個工程 - 型別 java project web project- 選擇依賴的jdk,可以使用myeclipse自帶的jdk,或者可以使用安裝的jdk* 建立包 package- * 在包裡面建立一個類- 類的命名規範:** 首字母要大寫比如: TestDemo1 UserManager* 在類裡面建立方法public void test1(引數列表) {方法體或者返回值;} - 方法的命名規範首字母小寫 比如:addNum()* 定義變數- 變數的命名規範** 首字母小寫,第二個單詞的首字母要大寫 ,比如 userName* 這些命名還有一種方式** 使用漢語拼音命名 yonghuming mima** 不能把漢語拼音和英文字母混合使用userMing* 命名的最基本的原則:看到名字知道是什麼含義* 程式碼需要有縮排* 執行程式 run as java applicationdebug as java application

2、debug的除錯模式(斷點除錯模式)

* 使用這種模式,除錯程式(看到程式裡面資料的變化)* 使用debug第一步需要設定一個斷點(讓程式執行停止在這一行)- 顯示出來行號- 雙擊左邊,出現一個圓點,表示設定了一個斷點* 使用debug as方式,執行程式- 提示是否進入到除錯介面,yes- 在斷點那一個,有一個綠色條,表示程式停止在這一行,沒有向下執行* 可以讓程式向下執行,- 使用 step over 快捷鍵是 F6(單步執行)- resume F8:表示除錯結束,直接向下執行** 比如當前的斷點之後還有斷點,跳到下一個斷點,**如果當前斷點後面沒有斷點,程式直接執行結束* debug另外一個用途** 檢視程式的原始碼** F5 step into:進入到方法** F7 step return :返回

3、myeclipse的快捷鍵的使用

* 程式碼提示 alt /* 快速導包 ctrl shift o* 單行註釋 ctrl /* 去掉單行註釋 ctrl /* 多行註釋 ctrl shift /* 去掉多行註釋 ctrl shift * 刪除行 ctrl d

4、junit的使用

* 單元測試* 測試物件是 是一個類中的方法* juint不是javase的一部分,想要使用匯入jar包** 但是,在myeclipse中自帶了junit的jar包* 首先junit版本 3.x 4.x* 單元測試方法時候,方法命名規則 public void 方法名() {}* 使用註解方式執行測試方法, 在方法的上面** @Test:表示方法進行單元測試--- @Testpublic void testAdd1() {TestJunit test01 = new TestJunit();Add(2, 3);}- 選中方法名稱,右鍵執行 點選run as --- junit test- 當出現綠色條,表示方法測試通過- 當出現了紅棕色條,表示方法測試不通過--- 要執行類中的多個測試方法,點選類中的其他位置,run as --- junit test** @Ignore :表示這個方法不進行單元測試** @Before: 在每個方法執行執行** @After:在每個方法之後執行** 斷言(瞭解)- rtEquals("測試期望的值", "方法執行的實際的值")jdk5.0新特性jdk 1.1 1.2 1.4 5.0** 泛型、列舉、靜態匯入、自動拆裝箱、增強for、可變引數** 反射

5、泛型的簡介

* 為什麼要使用泛型?- 一般使用在集合上** 比如現在把一個字串型別的值放入到集合裡面,這個時候,這個值放入到集合之後,失去本事的型別,只能是object型別,這個時候,比如想要對這個值進行型別轉換,很容易出現型別轉換錯誤,怎麼解決這個問題,可以使用泛型來解決* 在集合上如何使用泛型- 常用集合 list set map- 泛型語法 集合比如 List* 在泛型裡面寫是一個物件,String 不能寫基本的資料型別 比如int (****)** 寫基本的資料型別對應包裝類byte -- Byteshort -- Shortint -- Integerlong -- Longfloat -- Floatdouble -- Doublechar -- Characterboolean -- Boolean* 在list上使用泛型list的三種實現 ArrayList linkedList Vector程式碼:@Testpublic void testList() {Listlist = new ArrayList();("aaa");("bbb");("ccc");//遍歷list集合 有幾種方式 三種//普通for迴圈 迭代器 增強for//普通for迴圈for(int i=0;i<();i++) {String s=(i);tln(s);}tln("=================");//使用增強forfor (String s1 : list) {tln(s1);}tln("=================");//使用迭代器遍歷Iteratorit=ator();while(ext()) {tln(());}* 作業1: ArrayList linkedList Vector 這三個區別* 在set上使用泛型程式碼://泛型使用set集合上@Testpublic void testSet() {Setset=new HashSet();("www");("qqq");("zzz");//("qqq");//遍歷set 有幾種方式 兩種//迭代器 增強for//使用增強for遍歷for (String s2 : set) {tln(s2);}tln("=================");//使用迭代器遍歷Iteratorit1=ator();while(ext()) {tln(());}}* 在map上面使用泛型- map結構:key-valu形式程式碼://在map上使用泛型@Testpublic void testMap() {Mapmap=new HashMap();("aaa", "111");("bbb", "222");("ccc", "333");//遍歷map 有幾種遍歷方式 兩種// 1、獲取所有的key,通過key得到value 使用get方法// 2、獲取key和value的關係//使用第一種方式遍歷//獲取所有的keySetsets=et();//遍歷所有key返回的setfor (String key : sets) {//通過key得到valueString value=(key);tln(key+" : "+value);}tln("==============");//得到key和value的關係Setsets1=ySet();//遍歷sets1for (Entryentry : sets1) {//entry是key和value關係String keyv=ey();String valuev=alue();tln(keyv+" : "+valuev);}}

6、泛型使用在方法上

* 定義一個數組,實現指定位置上陣列元素的交換* 方法邏輯相同,只是資料型別不同,這個時候使用泛型方法* /** 使用泛型方法 需要定義一個型別 使用大寫字母表示 T :這個T表示任意的型別* 寫在返回值之前 void之前* =======表示定義了一個型別 這個型別是 T* 在下面就可以使用這個型別了 T* */public staticvoid swap1(T[] arr ,int a,int b) {T temp = arr[a];arr[a] = arr[b];arr[b] = temp;}** 作業2: 實現一個泛型方法,接受任意一個數組,顛倒陣列中所有元素

7、泛型在類上的使用(瞭解)

* 在一個類上定義一個型別,這個型別可以在類裡面直接使用* public class TestDemo04{//在類裡面可以直接使用T的型別T aa;public void test11(T bb) {}//寫一個靜態方法 在類上面定義的泛型,不能再靜態方法裡面使用public static void test12(A cc) {}}

8、列舉的簡介

* 什麼是列舉?** 需要在一定的範圍內取值,這個值只能是這個範圍內中的任意一個。** 現實場景:交通訊號燈,有三種顏色,但是每次只能亮三種顏色裡面的任意一個* 使用一個關鍵字 enum** enum Color3 {RED,GREEN,YELLOW;}* 列舉的構造方法也是私有的* 特殊列舉的操作(瞭解)** 在列舉類裡面有構造方法** 構造方法裡面有引數,需要在每個例項上面都寫引數** 在列舉類裡面有抽象方法** 在列舉的每個例項裡面都重寫這個抽象方法

9、列舉的api的操作

** name() :返回列舉的名稱** ordinal() :列舉的下標,下標從0開始** valueOf(ClassenumType, String name) :得到列舉的物件** 還有兩個方法,都是這兩個方法不在api裡面,編譯的時候生成兩個方法*** valueof(String name) 轉換列舉物件*** values() 獲得所有列舉物件陣列* 練習:列舉物件、列舉物件下標、列舉物件名稱表示之間的轉換- //知道列舉的物件,得到列舉名稱和下標@Testpublic void test1() {//得到列舉物件Color100 c100 = ;//列舉名稱String name = ();//列舉的下標int idx = nal();tln(name+" "+idx);}- //知道列舉的名稱,得到列舉的物件和下標@Testpublic void test2() {String name1 = "GREEN";//得到物件Color100 c1 = eOf(name1);//列舉下標int idx1 = nal();tln(idx1);}- //知道列舉的下標,得到列舉的物件和名稱@Testpublic void test3() {int idx2 = 2;//得到列舉的物件Color100[] cs = es();//根據下標得到物件Color100 c12 = cs[idx2];//得到列舉的名稱String name = ();tln(name);}

10、靜態匯入(瞭解)

* 可以在程式碼裡面,直接使用靜態匯入方式,匯入靜態方法或者常量* import static * import static ;import static ;** 比如現在實現一個計算器 在Math類裡面

11、自動拆裝箱

* 裝箱** 把基本的資料型別轉換成包裝類* 拆箱** 把包裝類轉換成基本的資料型別** //自動裝箱Integer i = 10;//自動拆箱int m = i;** 在jdk1.4裡面如何實現裝箱和拆箱- //在jdk1.4裡面實現拆裝箱public void test1() {//裝箱Integer m = new Integer(10); //拆箱 int a = alue();}** jdk是會向下相容- 比如 jdk1.4裡面寫的程式碼,這個時候到5.0裡面也可以執行** 練習:向下相容== 執行的結果是會呼叫 doSomething(double m)== 首先在jdk1.4裡面肯定呼叫這個方法,如果呼叫下面的方法,需要型別轉換,但是jdk1.4不能實現自動拆裝箱== 由於jdk是向下相容,所以,在jdk1.4呼叫這個方法,在jdk5.0裡面還是會呼叫這個方法public static void main(String[] args) {doSomething(10);}public static void doSomething(double m) {tln("double......");}public static void doSomething(Integer a){tln("integer.....");}** 記住:八種基本的資料型別對應的包裝類* int --- Integer* char--- Character

12、增強for迴圈(*****)

* 語法 for(遍歷出來的值 : 要遍歷的集合) {}- for(String s : list) {tln(s);}* 使用場景: 陣列;實現Iterable介面的集合 可以使用增強for迴圈* 在集合上使用增強for迴圈遍歷list set 實現了Iterator介面,所以可以使用增強for迴圈map不能使用增強for迴圈,沒有實現Iterator介面,所以不能使用增強for迴圈* 增強for迴圈出現目的:為了替代迭代器** 增強for底層就是迭代器實現的

13、內容補充

(1)泛型擦除* 首先泛型只是出現在原始碼階段,當編譯之後泛型不存在了(2)練習:實現一個泛型方法,接受任意型別的陣列,顛倒陣列中所有元素程式碼public staticvoid reverses(T[] arr1) {/** 基本思想:把第一個元素和最後一個元素交換位置,把第二個元素和倒數第二個元素交換位置。。。。* 交換 長度/2* *///遍歷陣列for(int i=0;i<th/2;i++) {/*int temp=arr1[0];arr1[0]=arr1[th-1];*/T temp=arr1[i];arr1[i]=arr1[th-i-1];arr1[th-i-1]=temp;}}

14、可變引數

* 可變引數可以應用在什麼場景:** 實現兩個數的相加,實現三個數的相加 四個數的相加-- 如果實現的多個方法,這些方法裡面邏輯基本相同,唯一不同的是傳遞的引數的個數,可以使用可變引數* 可變引數的定義方法 資料型別...陣列的名稱* 理解為一個數組,這個陣列儲存傳遞過來的引數- 程式碼public static void add1() {//nums理解為一個數組,這個陣列儲存傳遞過來的引數//tln(th);int sum = 0;//遍歷陣列for(int i=0;i<th;i++) {sum +=nums[i];}tln(sum);}* 注意的地方(1)可變引數需要寫在方法的引數列表中,不能單獨定義(2)在方法的引數列表中只能有一個可變引數(3)方法的引數列表中的可變引數,必須放在引數最後- add1(int a,)

15、反射的原理(********理解********)

* 應用在一些通用性比較高的程式碼 中* 後面學到的.框架,大多數都是使用反射來實現的* 在框架開發中,都是基於配置檔案開發** 在配置檔案中配置了類,可以通過反射得到類中的 所有內容,可以讓類中的某個方法來執行* 類中的所有內容:屬性、沒有引數的構造方法、有引數的構造方法、普通方法* 畫圖分析反射的原理* 首先需要把java檔案儲存到本地硬碟 * 編譯java檔案,成s檔案* 使用jvm,把class檔案通過類載入載入到記憶體中* 萬事萬物都是物件,class檔案在記憶體中使用Class類表示* 當使用反射時候,首先需要獲取到Class類,得到了這個類之後,就可以得到class檔案裡面的所有內容- 包含屬性 構造方法 普通方法* 屬性通過一個類 Filed* 構造方法通過一個類 Constructor* 普通方法通過一個類 Method

16、使用反射操作類裡面的無引數的構造方法(**會寫**)

* 首先獲取到Class類- // 獲取Class類Class clazz1 = s;Class clazz2 = new Person()lass();Class clazz3 = ame("on");* 比如: 要對一個類進行例項化,可以new,不使用new,怎麼獲取?- //得到ClassClass c3 = ame("on");//得到Person類的例項Person p = (Person) nstance();* 程式碼//操作無引數的構造方法@Testpublic void test1() throws Exception {//得到ClassClass c3 = ame("on");//得到Person類的例項Person p = (Person) nstance();//設定值ame("zhangsan");tln(ame());}

17、使用反射操作有引數的構造方法(**會寫**)

//操作有引數的構造方法@Testpublic void test2() throws Exception {//得到ClassClass c1 = ame("on");//使用有引數的構造方法//onstructors();//獲取所有的構造方法//傳遞是有引數的構造方法裡面引數型別,型別使用class形式傳遞Constructor cs = onstructor(s,s);//通過有引數的構造方法設定值//通過有引數的構造方法建立Person例項Person p1 = (Person) nstance("lisi","100");tln(d()+" "+ame());}

18、使用反射操作屬性(**會寫**)

* //操作name屬性@Testpublic void test3() {try {//得到Class類Class c2 = ame("on");//得到name屬性//eclaredFields();//表示得到所有的屬性//得到Person類的例項Person p11 = (Person) nstance();//通過這個方法得到屬性,引數是屬性的名稱Field f1 = eclaredField("name");//操作的是私有的屬性,不讓操作,需要設定可以操作私有屬性setAccessible(true),可以操作私有屬性ccessible(true);//設定name值 set方法,兩個引數:第一個引數類的例項,第二個引數是設定的值(p11, "wangwu"); //相當於 在 = "wangwu";tln((p11)); //相當於 }catch(Exception e) {tStackTrace();}}

19、使用泛型操作普通方法(**會寫**)

* 使用Method類表示普通方法* 程式碼//操作普通方法 ,比如操作 setName@Testpublic void test4() throws Exception {//得到Class類Class c4 = ame("on");//得到Person例項Person p4 = (Person) nstance();//得到普通方法//eclaredMethods();//得到所有的普通方法//傳遞兩個引數:第一個引數,方法名稱;第二個引數,方法裡面引數的型別Method m1 = eclaredMethod("setName", s);//讓setName方法執行 ,執行設定值//使用invoke(p4, "niuqi");傳遞兩個引數:第一個引數,person例項;第二個引數,設定的值//執行了invoke方法之後,相當於,執行了setName方法,同時通過這個方法設定了一個值是ke(p4, "niuqi");tln(ame());}* //操作的私有的方法 ,需要設定值是true* //ccessible(true);* 當操作的方法是靜態的方法時候,因為靜態方法呼叫方式是 類名.方法名,不需要類的例項* 使用反射操作靜態方式時候,也是不需要例項* 在invokie方法的第一個引數裡面,寫一個 null- ke(null, "niuqi")。