《大话设计模式》java实现之抽象工厂模式

本文介绍抽象工厂模式的应用,通过创建AccessFactory和SqlServerFactory两个具体工厂实现不同数据库环境下User和Department对象的创建与插入操作。该模式针对产品族设计,允许系统在不修改代码的情况下选择使用哪一组产品。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如前面所说,抽象工厂模式是针对产品族概念,一个factory对应多个产品的情况
UML图
这里写图片描述
代码结构
这里写图片描述

public class AccessDepartment implements IDepartment {

    @Override
    public void insert(Departmen departmen) {
        System.out.println("在Access中给Department表增加一条记录");
    }

}
public class AccessFactory implements IFactory {

    @Override
    public IUser createUser() {
        return new AccessUser();
    }

    @Override
    public IDepartment createDepartment() {
        return new AccessDepartment();
    }

}
public class AccessUser implements IUser {

    @Override
    public void insert(User user) {
        System.out.println("在Access中给User表增加一条记录");
    }

}
public class Client {
    public static void main(String[] args) {
        User user = new User();
        Departmen departmen = new Departmen();

        //IFactory factory = new SqlServerFactory();
        IFactory factory = new AccessFactory();

        IUser iUser = factory.createUser();
        iUser.insert(user);

        IDepartment iDepartment = factory.createDepartment();
        iDepartment.insert(departmen);
    }
}
public class Departmen {
    private int id;
    private String deptName;
}
public interface IDepartment {
    void insert(Departmen departmen);
}
public interface IFactory {
    IUser createUser();

    IDepartment createDepartment();
}
public interface IUser {
    void insert(User user);
}
public class SqlServerDepartment implements IDepartment {


    @Override
    public void insert(Departmen departmen) {
        System.out.println("在SQL Server中给Department表增加一条记录");
    }


}
public class SqlServerFactory implements IFactory {

    @Override
    public IUser createUser() {
        return new SqlServerUser();
    }

    @Override
    public IDepartment createDepartment() {
        return new SqlServerDepartment();
    }

}
public class SqlServerUser implements IUser {

    @Override
    public void insert(User user) {
        System.out.println("在SQL Server中给User表增加一条记录");
    }

}
public class User {
    private int id;
    private String name;

    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

}

运行结果
这里写图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值