download:Java并发编程入门与高并发面试
本课程将结合大量图示及代码演示,带你掌握多线程并发编程(线程安全,线程调度,线程封闭,同步容器等)与高并发处理思路与手段(扩容,缓存,队列,拆分等),构建完整的并发与高并发知识体系,胜任实际开发中并发与高并发问题的处理,倍增高薪面试成功率!
适合人群及技术储备要求
无论面试还是实际开发,几乎都会涉及并发相关知识及高并发相关场景处理,如果你想系统的学习一下并发编程
并了解一下实际的高并发场景及应对方案,那这门课就是为你准备的
技术储备要求:
有Java编程基础 / 有Linux基础 / 有MySQL基础 / 至少一个Java项目开发经验
添加依賴
org.testng
testng
6.8.8
test
運用DataProvider提供數據有兩種方式:把測試代码和測試數據放在同一個類中;把一切的數據提供都單獨寫在一個類里面,當測試數據比擬多時,這種辦法利於維護。用法1. 常規用法import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider1 {
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] { { 2, true ,"hi"}, { 6, false ,"test"}, { 19, true ,"good"},
{ 22, false ,"aha"}, { 23, true ,"loo"} };
}
//參數必需要分歧
@Test(dataProvider = "test1")
public void testPrimeNumberChecker(Integer inputNumber,
Boolean expectedResult, String test) {
System.out.println(inputNumber + " " + expectedResult+" "+test);
}
}
2. 帶Method參數的DataProvider假如希望DataProvider對不同的Test辦法運用不同的dataprovider,那麼在DataProvider中能夠運用Method參數import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import java.lang.reflect.Method;
public class ParamTestWithDataProvider2 {
@Test(dataProvider = "provider")
public void getFirst(String name, int age) {
System.out.println("第一組"+name);
}
@Test(dataProvider = "provider")
public void getSecond(String name, int age) {
System.out.println("第二組 " + name);
}
@DataProvider(name = "provider")
public Object[][] provider(Method method) {
Object[][] objects;
if (method.getName().equals("getFirst")) { //假如調用該DataProvider的函數是getFirst,那麼就返回這個數組
objects = new Object[][] { { "cq1", 20 }, { "cq2", 22 } };
} else if (method.getName().equals("getSecond")) {//假如調用該DataProvider的函數是getSecond,那麼就返回這個數組
objects = new Object[][] { { "cq3", 20 }, { "cq4", 22 } };
} else { //假如調用該DataProvider的函數不是getFirst也不是getSecond,那麼就返回這個數組
objects = new Object[][] { {"cq5",33}, {"cq6",34} };
}
return objects;
}
}
3. 經過DataProviderClass 把測試數據文件引過來import org.testng.annotations.DataProvider;
public class DataProviderMethod {
//無指定數據稱號,默許運用辦法名
@DataProvider
public static Object[][] NoNameMethod(){
return new Object[][]{
{"DataWithNoName1"},
{"DataWithNoName2"},
{"DataWithNoName3"}
};
}
//指定稱號1
@DataProvider(name="dataprovider1")
public static Object[][] dataProvider1(){
return new Object[][]{
{"dataprovider1-1"},
{"dataprovider1-2"}
};
}
//指定稱號2
@DataProvider(name="dataprovider2")
public static Object[][] dataProvider2(){
return new Object[][]{
{"dataprovider2-1"},
{"dataprovider2-2"}
};
}
}
import org.testng.annotations.Test;
public class ParamTestWithDataProvider3 {
@Test(dataProvider="NoNameMethod",dataProviderClass=DataProviderMethod.class)
public void doTestNG(String testdatas) {
System.out.println("未指定稱號,數據源名爲辦法名NoNameMethod:"+testdatas);
}
@
Test(dataProvider="dataprovider1",dataProviderClass=DataProviderMethod.class)
public void doTestNG1(String testdatas){
System.out.println("指定稱號,數據源稱號選择了dataprovider1:"+testdatas);
}
@Test(dataProvider="dataprovider2",dataProviderClass=DataProviderMethod.class)
public void doTestNG2(String testdatas){
System.out.println("指定稱號,數據源稱號選择了dataprovider2:"+testdatas);
}
}