JavaWeb基礎(chǔ)教程之Java基礎(chǔ)加強(qiáng)版
1、myeclipse的安裝和使用
* eclipse:是一個(gè)免費(fèi)的開(kāi)發(fā)工具 * myeclipse:是一個(gè)收費(fèi)的插件,破解myeclipse, ** 安裝目錄的要求: 不能有中文和空格 ** 安裝完成之后,選擇一個(gè)工作空間 ,這個(gè)工作空間不能有中文和空格 * 破解myeclipse ** 運(yùn)行run.bat文件,但是運(yùn)行之前,必須要安裝jdk,通過(guò)配置環(huán)境變量 * myeclipse的使用 * 創(chuàng)建一個(gè)工程 - 類型 java project web project - 選擇依賴的jdk,可以使用myeclipse自帶的jdk,或者可以使用安裝的jdk * 創(chuàng)建包 package - cn.itcast.test XX.XX.XX * 在包里面創(chuàng)建一個(gè)類 - 類的命名規(guī)范: ** 首字母要大寫 比如: TestDemo1 UserManager * 在類里面創(chuàng)建方法 public void test1(參數(shù)列表) { 方法體或者返回值; } - 方法的命名規(guī)范 首字母小寫 比如:addNum() * 定義變量 - 變量的命名規(guī)范 ** 首字母小寫,第二個(gè)單詞的首字母要大寫 ,比如 userName * 這些命名還有一種方式 ** 使用漢語(yǔ)拼音命名 yonghuming mima ** 不能把漢語(yǔ)拼音和英文字母混合使用 userMing * 命名的最基本的原則:看到名字知道是什么含義 * 代碼需要有縮進(jìn) * 運(yùn)行程序 run as java application debug as java application
2、debug的調(diào)試模式(斷點(diǎn)調(diào)試模式)
* 使用這種模式,調(diào)試程序(看到程序里面數(shù)據(jù)的變化) * 使用debug第一步需要設(shè)置一個(gè)斷點(diǎn)(讓程序運(yùn)行停止在這一行) - 顯示出來(lái)行號(hào) - 雙擊左邊,出現(xiàn)一個(gè)圓點(diǎn),表示設(shè)置了一個(gè)斷點(diǎn) * 使用debug as方式,運(yùn)行程序 - 提示是否進(jìn)入到調(diào)試界面,yes - 在斷點(diǎn)那一個(gè),有一個(gè)綠色條,表示程序停止在這一行,沒(méi)有向下運(yùn)行 * 可以讓程序向下執(zhí)行, - 使用 step over 快捷鍵是 F6(單步執(zhí)行) - resume F8:表示調(diào)試結(jié)束,直接向下運(yùn)行 ** 比如當(dāng)前的斷點(diǎn)之后還有斷點(diǎn),跳到下一個(gè)斷點(diǎn), ** 如果當(dāng)前斷點(diǎn)后面沒(méi)有斷點(diǎn),程序直接運(yùn)行結(jié)束 * debug另外一個(gè)用途 ** 查看程序的源代碼 ** F5 step into:進(jìn)入到方法 ** F7 step return :返回
3、myeclipse的快捷鍵的使用
* 代碼提示 alt / * 快速導(dǎo)包 ctrl shift o * 單行注釋 ctrl / * 去掉單行注釋 ctrl / * 多行注釋 ctrl shift / * 去掉多行注釋 ctrl shift \ * 刪除行 ctrl d
4、junit的使用
* 單元測(cè)試 * 測(cè)試對(duì)象是 是一個(gè)類中的方法 * juint不是javase的一部分,想要使用導(dǎo)入jar包 ** 但是,在myeclipse中自帶了junit的jar包 * 首先junit版本 3.x 4.x * 單元測(cè)試方法時(shí)候,方法命名規(guī)則 public void 方法名() {} * 使用注解方式運(yùn)行測(cè)試方法, 在方法的上面 ** @Test:表示方法進(jìn)行單元測(cè)試 --- @Test public void testAdd1() { TestJunit test01 = new TestJunit(); test01.testAdd(2, 3); } - 選中方法名稱,右鍵運(yùn)行 點(diǎn)擊run as --- junit test - 當(dāng)出現(xiàn)綠色條,表示方法測(cè)試通過(guò) - 當(dāng)出現(xiàn)了紅棕色條,表示方法測(cè)試不通過(guò) --- 要運(yùn)行類中的多個(gè)測(cè)試方法,點(diǎn)擊類中的其他位置,run as --- junit test ** @Ignore :表示這個(gè)方法不進(jìn)行單元測(cè)試 ** @Before: 在每個(gè)方法執(zhí)行運(yùn)行 ** @After:在每個(gè)方法之后運(yùn)行 ** 斷言(了解) - Assert.assertEquals("測(cè)試期望的值", "方法運(yùn)行的實(shí)際的值") jdk5.0新特性 jdk 1.1 1.2 1.4 5.0 ** 泛型、枚舉、靜態(tài)導(dǎo)入、自動(dòng)拆裝箱、增強(qiáng)for、可變參數(shù) ** 反射
5、泛型的簡(jiǎn)介
* 為什么要使用泛型? - 一般使用在集合上 ** 比如現(xiàn)在把一個(gè)字符串類型的值放入到集合里面,這個(gè)時(shí)候,這個(gè)值放入到集合之后,失去本事的類型,只能是object類型, 這個(gè)時(shí)候,比如想要對(duì)這個(gè)值進(jìn)行類型轉(zhuǎn)換,很容易出現(xiàn)類型轉(zhuǎn)換錯(cuò)誤,怎么解決這個(gè)問(wèn)題,可以使用泛型來(lái)解決 * 在集合上如何使用泛型 - 常用集合 list set map - 泛型語(yǔ)法 集合<String> 比如 List<String> * 在泛型里面寫是一個(gè)對(duì)象,String 不能寫基本的數(shù)據(jù)類型 比如int (****) ** 寫基本的數(shù)據(jù)類型對(duì)應(yīng)包裝類 byte -- Byte short -- Short int -- Integer long -- Long float -- Float double -- Double char -- Character boolean -- Boolean * 在list上使用泛型 list的三種實(shí)現(xiàn) ArrayList linkedList Vector 代碼: @Test public void testList() { List<String> list = new ArrayList<String>(); list.add("aaa"); list.add("bbb"); list.add("ccc"); //遍歷list集合 有幾種方式 三種 //普通for循環(huán) 迭代器 增強(qiáng)for //普通for循環(huán) for(int i=0;i<list.size();i++) { String s = list.get(i); System.out.println(s); } System.out.println("================="); //使用增強(qiáng)for for (String s1 : list) { System.out.println(s1); } System.out.println("================="); //使用迭代器遍歷 Iterator<String> it = list.iterator(); while(it.hasNext()) { System.out.println(it.next()); } * 作業(yè)1: ArrayList linkedList Vector 這三個(gè)區(qū)別 * 在set上使用泛型 代碼: //泛型使用set集合上 @Test public void testSet() { Set<String> set = new HashSet<String>(); set.add("www"); set.add("qqq"); set.add("zzz"); //set.add("qqq"); //遍歷set 有幾種方式 兩種 //迭代器 增強(qiáng)for //使用增強(qiáng)for遍歷 for (String s2 : set) { System.out.println(s2); } System.out.println("================="); //使用迭代器遍歷 Iterator<String> it1 = set.iterator(); while(it1.hasNext()) { System.out.println(it1.next()); } } * 在map上面使用泛型 - map結(jié)構(gòu):key-valu形式 代碼: //在map上使用泛型 @Test public void testMap() { Map<String,String> map = new HashMap<String,String>(); map.put("aaa", "111"); map.put("bbb", "222"); map.put("ccc", "333"); //遍歷map 有幾種遍歷方式 兩種 // 1、獲取所有的key,通過(guò)key得到value 使用get方法 // 2、獲取key和value的關(guān)系 //使用第一種方式遍歷 //獲取所有的key Set<String> sets = map.keySet(); //遍歷所有key返回的set for (String key : sets) { //通過(guò)key得到value String value = map.get(key); System.out.println(key+" : "+value); } System.out.println("=============="); //得到key和value的關(guān)系 Set<Entry<String, String>> sets1 = map.entrySet(); //遍歷sets1 for (Entry<String, String> entry : sets1) { //entry是key和value關(guān)系 String keyv = entry.getKey(); String valuev = entry.getValue(); System.out.println(keyv+" : "+valuev); } }
6、泛型使用在方法上
* 定義一個(gè)數(shù)組,實(shí)現(xiàn)指定位置上數(shù)組元素的交換 * 方法邏輯相同,只是數(shù)據(jù)類型不同,這個(gè)時(shí)候使用泛型方法 * /* * 使用泛型方法 需要定義一個(gè)類型 使用大寫字母表示 T :這個(gè)T表示任意的類型 * 寫在返回值之前 void之前 <T> * =======表示定義了一個(gè)類型 這個(gè)類型是 T * 在下面就可以使用這個(gè)類型了 T * */ public static <T> void swap1(T[] arr ,int a,int b) { T temp = arr[a]; arr[a] = arr[b]; arr[b] = temp; } ** 作業(yè)2: 實(shí)現(xiàn)一個(gè)泛型方法,接受任意一個(gè)數(shù)組,顛倒數(shù)組中所有元素
7、泛型在類上的使用(了解)
* 在一個(gè)類上定義一個(gè)類型,這個(gè)類型可以在類里面直接使用 * public class TestDemo04<T> { //在類里面可以直接使用T的類型 T aa; public void test11(T bb) {} //寫一個(gè)靜態(tài)方法 在類上面定義的泛型,不能再靜態(tài)方法里面使用 public static <A> void test12(A cc) {} }
8、枚舉的簡(jiǎn)介
* 什么是枚舉? ** 需要在一定的范圍內(nèi)取值,這個(gè)值只能是這個(gè)范圍內(nèi)中的任意一個(gè)。 ** 現(xiàn)實(shí)場(chǎng)景:交通信號(hào)燈,有三種顏色,但是每次只能亮三種顏色里面的任意一個(gè) * 使用一個(gè)關(guān)鍵字 enum ** enum Color3 { RED,GREEN,YELLOW; } * 枚舉的構(gòu)造方法也是私有的 * 特殊枚舉的操作(了解) ** 在枚舉類里面有構(gòu)造方法 ** 構(gòu)造方法里面有參數(shù),需要在每個(gè)實(shí)例上面都寫參數(shù) ** 在枚舉類里面有抽象方法 ** 在枚舉的每個(gè)實(shí)例里面都重寫這個(gè)抽象方法
9、枚舉的api的操作
** name() :返回枚舉的名稱 ** ordinal() :枚舉的下標(biāo),下標(biāo)從0開(kāi)始 ** valueOf(Class<T> enumType, String name) :得到枚舉的對(duì)象 ** 還有兩個(gè)方法,都是這兩個(gè)方法不在api里面,編譯的時(shí)候生成兩個(gè)方法 *** valueof(String name) 轉(zhuǎn)換枚舉對(duì)象 *** values() 獲得所有枚舉對(duì)象數(shù)組 * 練習(xí):枚舉對(duì)象、枚舉對(duì)象下標(biāo)、枚舉對(duì)象名稱表示之間的轉(zhuǎn)換 - //知道枚舉的對(duì)象,得到枚舉名稱和下標(biāo) @Test public void test1() { //得到枚舉對(duì)象 Color100 c100 = Color100.RED; //枚舉名稱 String name = c100.name(); //枚舉的下標(biāo) int idx = c100.ordinal(); System.out.println(name+" "+idx); } - //知道枚舉的名稱,得到枚舉的對(duì)象和下標(biāo) @Test public void test2() { String name1 = "GREEN"; //得到對(duì)象 Color100 c1 = Color100.valueOf(name1); //枚舉下標(biāo) int idx1 = c1.ordinal(); System.out.println(idx1); } - //知道枚舉的下標(biāo),得到枚舉的對(duì)象和名稱 @Test public void test3() { int idx2 = 2; //得到枚舉的對(duì)象 Color100[] cs = Color100.values(); //根據(jù)下標(biāo)得到對(duì)象 Color100 c12 = cs[idx2]; //得到枚舉的名稱 String name = c12.name(); System.out.println(name); }
10、靜態(tài)導(dǎo)入(了解)
* 可以在代碼里面,直接使用靜態(tài)導(dǎo)入方式,導(dǎo)入靜態(tài)方法或者常量 * import static XX.XX.xxx * import static java.lang.System.out; import static java.util.Arrays.sort; ** 比如現(xiàn)在實(shí)現(xiàn)一個(gè)計(jì)算器 在Math類里面
11、自動(dòng)拆裝箱
* 裝箱 ** 把基本的數(shù)據(jù)類型轉(zhuǎn)換成包裝類 * 拆箱 ** 把包裝類轉(zhuǎn)換成基本的數(shù)據(jù)類型 ** //自動(dòng)裝箱 Integer i = 10; //自動(dòng)拆箱 int m = i; ** 在jdk1.4里面如何實(shí)現(xiàn)裝箱和拆箱 - //在jdk1.4里面實(shí)現(xiàn)拆裝箱 public void test1() { //裝箱 Integer m = new Integer(10); //拆箱 int a = m.intValue(); } ** jdk是會(huì)向下兼容 - 比如 jdk1.4里面寫的代碼,這個(gè)時(shí)候到5.0里面也可以運(yùn)行 ** 練習(xí):向下兼容 == 執(zhí)行的結(jié)果是會(huì)調(diào)用 doSomething(double m) == 首先在jdk1.4里面肯定調(diào)用這個(gè)方法,如果調(diào)用下面的方法,需要類型轉(zhuǎn)換,但是jdk1.4不能實(shí)現(xiàn)自動(dòng)拆裝箱 == 由于jdk是向下兼容,所以,在jdk1.4調(diào)用這個(gè)方法,在jdk5.0里面還是會(huì)調(diào)用這個(gè)方法 public static void main(String[] args) { doSomething(10); } public static void doSomething(double m) { System.out.println("double......"); } public static void doSomething(Integer a){ System.out.println("integer....."); } ** 記住:八種基本的數(shù)據(jù)類型對(duì)應(yīng)的包裝類 * int --- Integer * char--- Character
12、增強(qiáng)for循環(huán)(*****)
* 語(yǔ)法 for(遍歷出來(lái)的值 : 要遍歷的集合) {} - for(String s : list) { System.out.println(s); } * 使用場(chǎng)景: 數(shù)組;實(shí)現(xiàn)Iterable接口的集合 可以使用增強(qiáng)for循環(huán) * 在集合上使用增強(qiáng)for循環(huán)遍歷 list set 實(shí)現(xiàn)了Iterator接口,所以可以使用增強(qiáng)for循環(huán) map不能使用增強(qiáng)for循環(huán),沒(méi)有實(shí)現(xiàn)Iterator接口,所以不能使用增強(qiáng)for循環(huán) * 增強(qiáng)for循環(huán)出現(xiàn)目的:為了替代迭代器 ** 增強(qiáng)for底層就是迭代器實(shí)現(xiàn)的
13、內(nèi)容補(bǔ)充
(1)泛型擦除 * 首先泛型只是出現(xiàn)在源代碼階段,當(dāng)編譯之后泛型不存在了 (2)練習(xí):實(shí)現(xiàn)一個(gè)泛型方法,接受任意類型的數(shù)組,顛倒數(shù)組中所有元素 代碼 public static <T> void reverses(T[] arr1) { /* * 基本思想:把第一個(gè)元素和最后一個(gè)元素交換位置,把第二個(gè)元素和倒數(shù)第二個(gè)元素交換位置。。。。 * 交換 長(zhǎng)度/2 * */ //遍歷數(shù)組 for(int i=0;i<arr1.length/2;i++) { /*int temp = arr1[0]; arr1[0] = arr1[arr1.length-1];*/ T temp = arr1[i]; arr1[i] = arr1[arr1.length-i-1]; arr1[arr1.length-i-1] = temp; } }
14、可變參數(shù)
* 可變參數(shù)可以應(yīng)用在什么場(chǎng)景: ** 實(shí)現(xiàn)兩個(gè)數(shù)的相加,實(shí)現(xiàn)三個(gè)數(shù)的相加 四個(gè)數(shù)的相加 -- 如果實(shí)現(xiàn)的多個(gè)方法,這些方法里面邏輯基本相同,唯一不同的是傳遞的參數(shù)的個(gè)數(shù),可以使用可變參數(shù) * 可變參數(shù)的定義方法 數(shù)據(jù)類型...數(shù)組的名稱 * 理解為一個(gè)數(shù)組,這個(gè)數(shù)組存儲(chǔ)傳遞過(guò)來(lái)的參數(shù) - 代碼 public static void add1(int...nums) { //nums理解為一個(gè)數(shù)組,這個(gè)數(shù)組存儲(chǔ)傳遞過(guò)來(lái)的參數(shù) //System.out.println(nums.length); int sum = 0; //遍歷數(shù)組 for(int i=0;i<nums.length;i++) { sum += nums[i]; } System.out.println(sum); } * 注意的地方 (1)可變參數(shù)需要寫在方法的參數(shù)列表中,不能單獨(dú)定義 (2)在方法的參數(shù)列表中只能有一個(gè)可變參數(shù) (3)方法的參數(shù)列表中的可變參數(shù),必須放在參數(shù)最后 - add1(int a,int...nums)
15、反射的原理(********理解********)
* 應(yīng)用在一些通用性比較高的代碼 中 * 后面學(xué)到的框架,大多數(shù)都是使用反射來(lái)實(shí)現(xiàn)的 * 在框架開(kāi)發(fā)中,都是基于配置文件開(kāi)發(fā) ** 在配置文件中配置了類,可以通過(guò)反射得到類中的 所有內(nèi)容,可以讓類中的某個(gè)方法來(lái)執(zhí)行 * 類中的所有內(nèi)容:屬性、沒(méi)有參數(shù)的構(gòu)造方法、有參數(shù)的構(gòu)造方法、普通方法 * 畫圖分析反射的原理 * 首先需要把java文件保存到本地硬盤 .java * 編譯java文件,成.class文件 * 使用jvm,把class文件通過(guò)類加載加載到內(nèi)存中 * 萬(wàn)事萬(wàn)物都是對(duì)象,class文件在內(nèi)存中使用Class類表示 * 當(dāng)使用反射時(shí)候,首先需要獲取到Class類,得到了這個(gè)類之后,就可以得到class文件里面的所有內(nèi)容 - 包含屬性 構(gòu)造方法 普通方法 * 屬性通過(guò)一個(gè)類 Filed * 構(gòu)造方法通過(guò)一個(gè)類 Constructor * 普通方法通過(guò)一個(gè)類 Method
16、使用反射操作類里面的無(wú)參數(shù)的構(gòu)造方法(**會(huì)寫**)
* 首先獲取到Class類 - // 獲取Class類 Class clazz1 = Person.class; Class clazz2 = new Person().getClass(); Class clazz3 = Class.forName("cn.itcast.test09.Person"); * 比如: 要對(duì)一個(gè)類進(jìn)行實(shí)例化,可以new,不使用new,怎么獲?。? - //得到Class Class c3 = Class.forName("cn.itcast.test09.Person"); //得到Person類的實(shí)例 Person p = (Person) c3.newInstance(); * 代碼 //操作無(wú)參數(shù)的構(gòu)造方法 @Test public void test1() throws Exception { //得到Class Class c3 = Class.forName("cn.itcast.test09.Person"); //得到Person類的實(shí)例 Person p = (Person) c3.newInstance(); //設(shè)置值 p.setName("zhangsan"); System.out.println(p.getName()); }
17、使用反射操作有參數(shù)的構(gòu)造方法(**會(huì)寫**)
//操作有參數(shù)的構(gòu)造方法 @Test public void test2() throws Exception { //得到Class Class c1 = Class.forName("cn.itcast.test09.Person"); //使用有參數(shù)的構(gòu)造方法 //c1.getConstructors();//獲取所有的構(gòu)造方法 //傳遞是有參數(shù)的構(gòu)造方法里面參數(shù)類型,類型使用class形式傳遞 Constructor cs = c1.getConstructor(String.class,String.class); //通過(guò)有參數(shù)的構(gòu)造方法設(shè)置值 //通過(guò)有參數(shù)的構(gòu)造方法創(chuàng)建Person實(shí)例 Person p1 = (Person) cs.newInstance("lisi","100"); System.out.println(p1.getId()+" "+p1.getName()); }
18、使用反射操作屬性(**會(huì)寫**)
* //操作name屬性 @Test public void test3() { try { //得到Class類 Class c2 = Class.forName("cn.itcast.test09.Person"); //得到name屬性 //c2.getDeclaredFields();//表示得到所有的屬性 //得到Person類的實(shí)例 Person p11 = (Person) c2.newInstance(); //通過(guò)這個(gè)方法得到屬性,參數(shù)是屬性的名稱 Field f1 = c2.getDeclaredField("name"); //操作的是私有的屬性,不讓操作,需要設(shè)置可以操作私有屬性setAccessible(true),可以操作私有屬性 f1.setAccessible(true); //設(shè)置name值 set方法,兩個(gè)參數(shù):第一個(gè)參數(shù)類的實(shí)例,第二個(gè)參數(shù)是設(shè)置的值 f1.set(p11, "wangwu"); //相當(dāng)于 在 p.name = "wangwu"; System.out.println(f1.get(p11)); //相當(dāng)于 p.name }catch(Exception e) { e.printStackTrace(); } }
19、使用泛型操作普通方法(**會(huì)寫**)
* 使用Method類表示普通方法 * 代碼 //操作普通方法 ,比如操作 setName @Test public void test4() throws Exception { //得到Class類 Class c4 = Class.forName("cn.itcast.test09.Person"); //得到Person實(shí)例 Person p4 = (Person) c4.newInstance(); //得到普通方法 //c4.getDeclaredMethods();//得到所有的普通方法 //傳遞兩個(gè)參數(shù):第一個(gè)參數(shù),方法名稱;第二個(gè)參數(shù),方法里面參數(shù)的類型 Method m1 = c4.getDeclaredMethod("setName", String.class); //讓setName方法執(zhí)行 ,執(zhí)行設(shè)置值 //使用invoke(p4, "niuqi");傳遞兩個(gè)參數(shù):第一個(gè)參數(shù),person實(shí)例;第二個(gè)參數(shù),設(shè)置的值 //執(zhí)行了invoke方法之后,相當(dāng)于,執(zhí)行了setName方法,同時(shí)通過(guò)這個(gè)方法設(shè)置了一個(gè)值是niuqi m1.invoke(p4, "niuqi"); System.out.println(p4.getName()); } * //操作的私有的方法 ,需要設(shè)置值是true * //m1.setAccessible(true); * 當(dāng)操作的方法是靜態(tài)的方法時(shí)候,因?yàn)殪o態(tài)方法調(diào)用方式是 類名.方法名,不需要類的實(shí)例 * 使用反射操作靜態(tài)方式時(shí)候,也是不需要實(shí)例 * 在invokie方法的第一個(gè)參數(shù)里面,寫一個(gè) null - m1.invoke(null, "niuqi");
以上所述是小編給大家介紹的JavaWeb基礎(chǔ)教程之Java基礎(chǔ)加強(qiáng)版,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- javaweb之web入門基礎(chǔ)
- JavaWeb實(shí)現(xiàn)打印功能
- JavaWeb實(shí)現(xiàn)用戶登錄注冊(cè)功能實(shí)例代碼(基于Servlet+JSP+JavaBean模式)
- 使用JavaWeb webSocket實(shí)現(xiàn)簡(jiǎn)易的點(diǎn)對(duì)點(diǎn)聊天功能實(shí)例代碼
- 解決javaWEB中前后臺(tái)中文亂碼問(wèn)題的3種方法
- JavaWeb實(shí)現(xiàn)文件上傳下載功能實(shí)例解析
- 學(xué)習(xí)javaweb如何配置Tomcat的熱啟動(dòng)
- javaweb中靜態(tài)文件的常用處理方法匯總
- JavaWeb編程 Servlet的基本配置
相關(guān)文章
Java最常用的6個(gè)簡(jiǎn)單的計(jì)算題
本篇文章給大家整理的在JAVA中最常用到的簡(jiǎn)單的計(jì)算題,對(duì)此有興趣的朋友可以測(cè)試參考下。2018-02-02request如何獲取body的json數(shù)據(jù)
這篇文章主要介紹了request如何獲取body的json數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Spring負(fù)載均衡LoadBalancer使用詳解
這篇文章主要介紹了Spring負(fù)載均衡LoadBalancer使用詳解,Spring Cloud LoadBalancer是Spring Cloud官方自己提供的客戶端負(fù)載均衡器, 用來(lái)替代Ribbon,Spring官方提供了兩種客戶端都可以使用loadbalancer,需要的朋友可以參考下2023-11-11淺談hashmap為什么查詢時(shí)間復(fù)雜度為O(1)
這篇文章主要介紹了hashmap為什么查詢時(shí)間復(fù)雜度為O(1),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Python基礎(chǔ)之如何使用multiprocessing模塊
今天帶大家學(xué)習(xí)python多進(jìn)程的相關(guān)知識(shí),文中對(duì)multiprocessing模塊的使用作了非常詳細(xì)的介紹,需要的朋友可以參考下2021-06-06Java Web實(shí)現(xiàn)session過(guò)期后自動(dòng)跳轉(zhuǎn)到登陸頁(yè)功能【基于過(guò)濾器】
這篇文章主要介紹了Java Web實(shí)現(xiàn)session過(guò)期后自動(dòng)跳轉(zhuǎn)到登陸頁(yè)功能,涉及java過(guò)濾器針對(duì)session的判斷與跳轉(zhuǎn)相關(guān)操作技巧,需要的朋友可以參考下2017-11-11Spring?Boot整合Zookeeper實(shí)現(xiàn)分布式鎖的場(chǎng)景分析
這篇文章主要介紹了Spring?Boot整合Zookeeper實(shí)現(xiàn)分布式鎖,zk實(shí)現(xiàn)分布式鎖完全是依靠zk節(jié)點(diǎn)類型當(dāng)中的臨時(shí)序號(hào)節(jié)點(diǎn)來(lái)實(shí)現(xiàn)的,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06java工具類SendEmailUtil實(shí)現(xiàn)發(fā)送郵件
這篇文章主要為大家詳細(xì)介紹了java工具類SendEmailUtil實(shí)現(xiàn)發(fā)送郵件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02