思維導圖
*eclipse:是一個免費的開發工具
*myeclipse:是一個收費的插件,破解myeclipse,
**安裝目錄的要求: 不能有中文和空格
**安裝完成之後,選擇一個工作空間 ,這個工作空間不能有中文和空格
*破解myeclipse
**運行run.bat文件,但是運行之前,必須要安裝jdk,通過配置環境變量
*myeclipse的使用
*創建一個工程
-類型 javaproject web project
-選擇依賴的jdk,可以使用myeclipse自帶的jdk,或者可以使用安裝的jdk
*創建包 package
-cn.itcast.test XX.XX.XX
*在包裡面創建一個類
-類的命名規范:
**首字母要大寫
比如: TestDemo1 UserManager
*在類裡面創建方法
publicvoid test1(參數列表) {
方法體或者返回值;
}
-方法的命名規范
首字母小寫 比如:addNum()
*定義變量
-變量的命名規范
**首字母小寫,第二個單詞的首字母要大寫 ,比如 userName
*這些命名還有一種方式
**使用漢語拼音命名yonghuming mima
**不能把漢語拼音和英文字母混合使用
userMing
*命名的最基本的原則:看到名字知道是什麼含義
*代碼需要有縮進
*運行程序 run asjava application
debug asjava application
*使用這種模式,調試程序(看到程序裡面數據的變化)
*使用debug第一步需要設置一個斷點(讓程序運行停止在這一行)
-顯示出來行號
-雙擊左邊,出現一個圓點,表示設置了一個斷點
*使用debug as方式,運行程序
-提示是否進入到調試界面,yes
-在斷點那一個,有一個綠色條,表示程序停止在這一行,沒有向下運行
*可以讓程序向下執行,
-使用 step over 快捷鍵是 F6(單步執行)
-resume F8:表示調試結束,直接向下運行
**比如當前的斷點之後還有斷點,跳到下一個斷點,
** 如果當前斷點後面沒有斷點,程序直接運行結束
*debug另外一個用途
**查看程序的源代碼
**F5 step into:進入到方法
**F7 step return :返回
*代碼提示 alt /
*快速導包 ctrlshift o
*單行注釋 ctrl /
*去掉單行注釋 ctrl /
*多行注釋 ctrl shift/
*去掉多行注釋 ctrlshift \
*刪除行 ctrl d
*單元測試
*測試對象是 是一個類中的方法
*juint不是javase的一部分,想要使用導入jar包
**但是,在myeclipse中自帶了junit的jar包
*首先junit版本 3.x 4.x
*單元測試方法時候,方法命名規則 public void 方法名() {}
*使用注解方式運行測試方法, 在方法的上面
**@Test:表示方法進行單元測試
--- @Test
publicvoid testAdd1() {
TestJunittest01 = new TestJunit();
test01.testAdd(2,3);
}
-選中方法名稱,右鍵運行 點擊run as --- junit test
-當出現綠色條,表示方法測試通過
-當出現了紅棕色條,表示方法測試不通過
---要運行類中的多個測試方法,點擊類中的其他位置,run as --- junit test
**@Ignore :表示這個方法不進行單元測試
**@Before: 在每個方法執行運行
**@After:在每個方法之後運行
**斷言(了解)
-Assert.assertEquals("測試期望的值", "方法運行的實際的值")
jdk5.0新特性
jdk 1.11.2 1.4 5.0
** 泛型、枚舉、靜態導入、自動拆裝箱、增強for、可變參數
** 反射
*為什麼要使用泛型?
-一般使用在集合上
**比如現在把一個字符串類型的值放入到集合裡面,這個時候,這個值放入到集合之後,失去本事的類型,只能是object類型,
這個時候,比如想要對這個值進行類型轉換,很容易出現類型轉換錯誤,怎麼解決這個問題,可以使用泛型來解決
*在集合上如何使用泛型
-常用集合 list setmap
-泛型語法 集合
*在泛型裡面寫是一個對象,String不能寫基本的數據類型 比如int (****)
**寫基本的數據類型對應包裝類
byte-- Byte
short-- Short
int-- Integer
long-- Long
float-- Float
double-- Double
char -- Character
boolean-- Boolean
*在list上使用泛型
list的三種實現 ArrayList linkedList Vector
代碼:
@Test
publicvoid testList() {
List
list.add("aaa");
list.add("bbb");
list.add("ccc");
//遍歷list集合有幾種方式 三種
//普通for循環 迭代器增強for
//普通for循環
for(inti=0;i Strings = list.get(i); System.out.println(s); } System.out.println("================="); //使用增強for for(String s1 : list) { System.out.println(s1); } System.out.println("================="); //使用迭代器遍歷 Iterator while(it.hasNext()){ System.out.println(it.next()); } *作業1: ArrayList linkedList Vector 這三個區別 *在set上使用泛型 代碼: //泛型使用set集合上 @Test publicvoid testSet() { Set set.add("www"); set.add("qqq"); set.add("zzz"); //set.add("qqq"); //遍歷set 有幾種方式 兩種 //迭代器增強for //使用增強for遍歷 for(String s2 : set) { System.out.println(s2); } System.out.println("================="); //使用迭代器遍歷 Iterator while(it1.hasNext()){ System.out.println(it1.next()); } } *在map上面使用泛型 -map結構:key-valu形式 代碼: //在map上使用泛型 @Test publicvoid testMap() { Map map.put("aaa","111"); map.put("bbb","222"); map.put("ccc","333"); //遍歷map 有幾種遍歷方式兩種 //1、獲取所有的key,通過key得到value 使用get方法 //2、獲取key和value的關系 //使用第一種方式遍歷 //獲取所有的key Set //遍歷所有key返回的set for(String key : sets) { //通過key得到value Stringvalue = map.get(key); System.out.println(key+": "+value); } System.out.println("=============="); //得到key和value的關系 Set //遍歷sets1 for(Entry //entry是key和value關系 Stringkeyv = entry.getKey(); Stringvaluev = entry.getValue(); System.out.println(keyv+": "+valuev); } } *定義一個數組,實現指定位置上數組元素的交換 *方法邏輯相同,只是數據類型不同,這個時候使用泛型方法 */* * 使用泛型方法需要定義一個類型 使用大寫字母表示 T :這個T表示任意的類型 * 寫在返回值之前 void之前 * =======表示定義了一個類型這個類型是 T * 在下面就可以使用這個類型了 T * */ publicstatic Ttemp = arr[a]; arr[a]= arr[b]; arr[b]= temp; } **作業2: 實現一個泛型方法,接受任意一個數組,顛倒數組中所有元素 *在一個類上定義一個類型,這個類型可以在類裡面直接使用 *public class TestDemo04 //在類裡面可以直接使用T的類型 Taa; publicvoid test11(T bb) {} //寫一個靜態方法 在類上面定義的泛型,不能再靜態方法裡面使用 publicstatic void test12(A cc) {} } *什麼是枚舉? **需要在一定的范圍內取值,這個值只能是這個范圍內中的任意一個。 **現實場景:交通信號燈,有三種顏色,但是每次只能亮三種顏色裡面的任意一個 *使用一個關鍵字 enum **enum Color3 { RED,GREEN,YELLOW; } *枚舉的構造方法也是私有的 *特殊枚舉的操作(了解) **在枚舉類裡面有構造方法 **構造方法裡面有參數,需要在每個實例上面都寫參數 **在枚舉類裡面有抽象方法 **在枚舉的每個實例裡面都重寫這個抽象方法 **name() :返回枚舉的名稱 **ordinal() :枚舉的下標,下標從0開始 **valueOf(Class **還有兩個方法,都是這兩個方法不在api裡面,編譯的時候生成兩個方法 ***valueof(String name) 轉換枚舉對象 ***values() 獲得所有枚舉對象數組 *練習:枚舉對象、枚舉對象下標、枚舉對象名稱表示之間的轉換 -//知道枚舉的對象,得到枚舉名稱和下標 @Test publicvoid test1() { //得到枚舉對象 Color100c100 = Color100.RED; //枚舉名稱 Stringname = c100.name(); //枚舉的下標 intidx = c100.ordinal(); System.out.println(name+""+idx); } -//知道枚舉的名稱,得到枚舉的對象和下標 @Test publicvoid test2() { Stringname1 = "GREEN"; //得到對象 Color100c1 = Color100.valueOf(name1); //枚舉下標 intidx1 = c1.ordinal(); System.out.println(idx1); } -//知道枚舉的下標,得到枚舉的對象和名稱 @Test publicvoid test3() { intidx2 = 2; //得到枚舉的對象 Color100[]cs = Color100.values(); //根據下標得到對象 Color100c12 = cs[idx2]; //得到枚舉的名稱 Stringname = c12.name(); System.out.println(name); } *可以在代碼裡面,直接使用靜態導入方式,導入靜態方法或者常量 *import static XX.XX.xxx *import static java.lang.System.out; importstatic java.util.Arrays.sort; **比如現在實現一個計算器 在Math類裡面 *裝箱 **把基本的數據類型轉換成包裝類 *拆箱 **把包裝類轉換成基本的數據類型 ** //自動裝箱 Integeri = 10; //自動拆箱 intm = i; **在jdk1.4裡面如何實現裝箱和拆箱 -//在jdk1.4裡面實現拆裝箱 publicvoid test1() { //裝箱 Integerm = new Integer(10); //拆箱 inta = m.intValue(); } **jdk是會向下兼容 -比如 jdk1.4裡面寫的代碼,這個時候到5.0裡面也可以運行 **練習:向下兼容 ==執行的結果是會調用 doSomething(double m) ==首先在jdk1.4裡面肯定調用這個方法,如果調用下面的方法,需要類型轉換,但是jdk1.4不能實現自動拆裝箱 ==由於jdk是向下兼容,所以,在jdk1.4調用這個方法,在jdk5.0裡面還是會調用這個方法 publicstatic void main(String[] args) { doSomething(10); } publicstatic void doSomething(double m) { System.out.println("double......"); } publicstatic void doSomething(Integer a){ System.out.println("integer....."); } **記住:八種基本的數據類型對應的包裝類 *int --- Integer *char--- Character *語法 for(遍歷出來的值 : 要遍歷的集合) {} -for(String s : list) { System.out.println(s); } *使用場景: 數組;實現Iterable接口的集合 可以使用增強for循環 *在集合上使用增強for循環遍歷 list set 實現了Iterator接口,所以可以使用增強for循環 map不能使用增強for循環,沒有實現Iterator接口,所以不能使用增強for循環 *增強for循環出現目的:為了替代迭代器 **增強for底層就是迭代器實現的 (1)泛型擦除 *首先泛型只是出現在源代碼階段,當編譯之後泛型不存在了 (2)練習:實現一個泛型方法,接受任意類型的數組,顛倒數組中所有元素 代碼 publicstatic /* * 基本思想:把第一個元素和最後一個元素交換位置,把第二個元素和倒數第二個元素交換位置。。。。 * 交換長度/2 * */ //遍歷數組 for(inti=0;i
/*inttemp = arr1[0]; arr1[0]= arr1[arr1.length-1];*/ Ttemp = arr1[i]; arr1[i]= arr1[arr1.length-i-1]; arr1[arr1.length-i-1]= temp; } } *可變參數可以應用在什麼場景: **實現兩個數的相加,實現三個數的相加 四個數的相加 --如果實現的多個方法,這些方法裡面邏輯基本相同,唯一不同的是傳遞的參數的個數,可以使用可變參數 *可變參數的定義方法 數據類型...數組的名稱 *理解為一個數組,這個數組存儲傳遞過來的參數 -代碼 publicstatic void add1(int...nums) { //nums理解為一個數組,這個數組存儲傳遞過來的參數 //System.out.println(nums.length); intsum = 0; //遍歷數組 for(inti=0;i sum+= nums[i]; } System.out.println(sum); } *注意的地方 (1)可變參數需要寫在方法的參數列表中,不能單獨定義 (2)在方法的參數列表中只能有一個可變參數 (3)方法的參數列表中的可變參數,必須放在參數最後 -add1(int a,int...nums) *應用在一些通用性比較高的代碼 中 *後面學到的框架,大多數都是使用反射來實現的 *在框架開發中,都是基於配置文件開發 **在配置文件中配置了類,可以通過反射得到類中的 所有內容,可以讓類中的某個方法來執行 *類中的所有內容:屬性、沒有參數的構造方法、有參數的構造方法、普通方法 *畫圖分析反射的原理 *首先需要把java文件保存到本地硬盤 .java *編譯java文件,成.class文件 *使用jvm,把class文件通過類加載加載到內存中 *萬事萬物都是對象,class文件在內存中使用Class類表示 *當使用反射時候,首先需要獲取到Class類,得到了這個類之後,就可以得到class文件裡面的所有內容 -包含屬性 構造方法普通方法 *屬性通過一個類 Filed *構造方法通過一個類Constructor *普通方法通過一個類Method *首先獲取到Class類 -// 獲取Class類 Classclazz1 = Person.class; Classclazz2 = new Person().getClass(); Classclazz3 = Class.forName("cn.itcast.test09.Person"); *比如: 要對一個類進行實例化,可以new,不使用new,怎麼獲取? -//得到Class Classc3 = Class.forName("cn.itcast.test09.Person"); //得到Person類的實例 Personp = (Person) c3.newInstance(); *代碼 //操作無參數的構造方法 @Test publicvoid test1() throws Exception { //得到Class Classc3 = Class.forName("cn.itcast.test09.Person"); //得到Person類的實例 Personp = (Person) c3.newInstance(); //設置值 p.setName("zhangsan"); System.out.println(p.getName()); } //操作有參數的構造方法 @Test publicvoid test2() throws Exception { //得到Class Classc1 = Class.forName("cn.itcast.test09.Person"); //使用有參數的構造方法 //c1.getConstructors();//獲取所有的構造方法 //傳遞是有參數的構造方法裡面參數類型,類型使用class形式傳遞 Constructorcs = c1.getConstructor(String.class,String.class); //通過有參數的構造方法設置值 //通過有參數的構造方法創建Person實例 Personp1 = (Person) cs.newInstance("lisi","100"); System.out.println(p1.getId()+""+p1.getName()); } *//操作name屬性 @Test publicvoid test3() { try{ //得到Class類 Classc2 = Class.forName("cn.itcast.test09.Person"); //得到name屬性 //c2.getDeclaredFields();//表示得到所有的屬性 //得到Person類的實例 Personp11 = (Person) c2.newInstance(); //通過這個方法得到屬性,參數是屬性的名稱 Fieldf1 = c2.getDeclaredField("name"); //操作的是私有的屬性,不讓操作,需要設置可以操作私有屬性setAccessible(true),可以操作私有屬性 f1.setAccessible(true); //設置name值 set方法,兩個參數:第一個參數類的實例,第二個參數是設置的值 f1.set(p11,"wangwu"); //相當於 在 p.name = "wangwu"; System.out.println(f1.get(p11));//相當於 p.name }catch(Exceptione) { e.printStackTrace(); } } *使用Method類表示普通方法 *代碼 //操作普通方法 ,比如操作 setName @Test publicvoid test4() throws Exception { //得到Class類 Classc4 = Class.forName("cn.itcast.test09.Person"); //得到Person實例 Personp4 = (Person) c4.newInstance(); //得到普通方法 //c4.getDeclaredMethods();//得到所有的普通方法 //傳遞兩個參數:第一個參數,方法名稱;第二個參數,方法裡面參數的類型 Methodm1 = c4.getDeclaredMethod("setName", String.class); //讓setName方法執行 ,執行設置值 //使用invoke(p4, "niuqi");傳遞兩個參數:第一個參數,person實例;第二個參數,設置的值 //執行了invoke方法之後,相當於,執行了setName方法,同時通過這個方法設置了一個值是niuqi m1.invoke(p4,"niuqi"); System.out.println(p4.getName()); } *//操作的私有的方法 ,需要設置值是true *//m1.setAccessible(true); *當操作的方法是靜態的方法時候,因為靜態方法調用方式是 類名.方法名,不需要類的實例 *使用反射操作靜態方式時候,也是不需要實例 *在invokie方法的第一個參數裡面,寫一個 null -m1.invoke(null, "niuqi");
6、泛型使用在方法上7、泛型在類上的使用(了解)
8、枚舉的簡介
9、枚舉的api的操作
10、靜態導入(了解)
11、自動拆裝箱
12、增強for循環(*****)13、內容補充
14、可變參數
15、反射的原理(********理解********)
16、使用反射操作類裡面的無參數的構造方法(**會寫**)
17、使用反射操作有參數的構造方法(**會寫**)
18、使用反射操作屬性(**會寫**)
19、使用泛型操作普通方法(**會寫**)