簡單說,工廠和需要生產(chǎn)出來的對象只在生產(chǎn)的方法里有關(guān)聯(lián),但是每次新增新的實(shí)現(xiàn)類,需要修改工廠類的代碼
定義課程ICourse接口
public interface ICourse {
/**
* 錄制視頻
*/
void record();
}
定義ICourse兩個(gè)實(shí)現(xiàn)類
public class JavaCourse implements ICourse {
@Override
public void record() {
System.out.println("錄制Java視頻");
}
}
public class PythonCourse implements ICourse {
@Override
public void record() {
System.out.println("錄制Python視頻");
}
}
定義工廠類
public class CourseFactory {
/**
* 普通工廠
* 傳入名字返回對象
*
* @param name 需要?jiǎng)?chuàng)建的類的名字
* @return 沒找到對應(yīng)對象則返回null
*/
public static ICourse create(String name) {
if ("java".equals(name)) {
return new JavaCourse();
} else if ("python".equals(name)) {
return new PythonCourse();
} else {
return null;
}
}
/**
* 進(jìn)階工廠2
*
* @param clazz 傳入類文件
* @return 對應(yīng)對象
*/
public static ICourse create2(Class<? extends ICourse> clazz) {
if (clazz != null) {
try {
return clazz.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
e.printStackTrace();
System.out.println("CourseFactory獲取對象失敗");
}
}
return null;
}
}
具體使用
@Test
public void test2() {
ICourse java = CourseFactory.create("java");
assert java != null;
java.record();
ICourse python = CourseFactory.create("python");
assert python != null;
python.record();
}
@Test
public void test3(){
ICourse java = CourseFactory.create2(JavaCourse.class);
java.record();
ICourse python = CourseFactory.create2(PythonCourse.class);
python.record();
}
類關(guān)系

image.png
小結(jié)
簡單工廠顧名思義很簡單,看出來了吧,最終對外暴露的也就是一個(gè)工廠類,調(diào)用create方法就可以獲得對應(yīng)的實(shí)現(xiàn)類,缺點(diǎn)就在于新增一個(gè)實(shí)現(xiàn)類,就需要到工廠類中維護(hù)(不符合開閉原則);
具體使用
jdk中的Calendar.getInstance()方法以及l(fā)ogback的LoggerFactory.getLogger(String name)|(String clazz),都是簡單工廠設(shè)計(jì)模式。