简单工厂模式

文章是看了网上《设计模式之禅》第二版的,和网上其他文章写出来的。
简单工厂模式的类图:
这里写图片描述

抽象产品类
可以是抽象类 可以是接口,主要看需求是用接口 还是用抽象类。
因为我们重点制造出不同肤色的人,所以我们需要一个接口或者抽象类来被他们实现或者继承。
Human(抽象产品类) 可以是接口或者抽象类

//Human.java
public interface Human {
    void getColor();
    void talk();
}

具体产品类
具体产品类这里是黑人,黄种人,白种人。代码实现如下:

//BlackHuman.java
public class BlackHuman implements Human {
    @Override
    public void getColor() {
        System.out.println("黑种人黑色皮肤");
    }

    @Override
    public void talk() {
        System.out.println("说的是单字节语言");
    }
}
//YellowHuman.java
public class YellowHuman implements Human {
    @Override
    public void getColor() {
        System.out.println("黄种人黄色皮肤");
    }
    @Override
    public void talk() {
        System.out.println("黄种人说的是双字节语言");
    }
}
//WhiteHuman.java
public class WhiteHuman implements Human {
    @Override
    public void getColor() {
        System.out.println("白人是白色皮肤");
    }
    @Override
    public void talk() {
        System.out.println("白人说的是单字节语言");
    }
}

工厂类
负责生成产品对象的。在这里,工厂类是HumanFactory,这里用到了静态方法生产产品,确切来说,这是一个 简单静态工厂模式。
简单工厂模式是通过 switch case (或者if elseif)来写分支的。这就是工厂模式的最大区别之处。

//HumanFactory.java
public class HumanFactory {
    public static Human createHuman(int type){
        Human human = null;
        switch (type) {
        case 1:
            human = new WhiteHuman();
            break;
        case 2:
            human = new BlackHuman();
            break;
        case 3:
            human = new YellowHuman();
            break;
        }
        return human;
    }
}

客户
这里客户是女娲.

public class Nvwa {
    public static void main(String[] args) {
        System.out.println("--早出的第一批人是白色人种--");
        Human whiteHuman = HumanFactory.createHuman(1);
        whiteHuman.getColor();
        whiteHuman.talk();

        System.out.println("--第二次 是黑色人种--");
        Human blackHuman = HumanFactory.createHuman(2);
        blackHuman.getColor();
        blackHuman.talk();

        System.out.println("--最后 是黄色人种--");
        Human yellowHuman = HumanFactory.createHuman(3);
        yellowHuman.getColor();
        yellowHuman.talk();

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,我们发现是通过将`File`对象封装成`MultipartFile`对象来实现换的。但是`FTPFile`并不是与`File`对象兼容的类型,因此我们需要先将`FTPFile`对象换为`File`对象,然后再进行封装成`MultipartFile`对象。下面是一个实现该功能的示例代码: ```java import org.apache.commons.net.ftp.FTPClient; import org.springframework.mock.web.MockMultipartFile; import org.springframework.web.multipart.MultipartFile; import java.io.*; public class FTPFileToMultipartFile { public static MultipartFile convert(FTPClient ftpClient, String remoteFilePath) throws IOException { InputStream inputStream = null; ByteArrayOutputStream outputStream = null; MultipartFile multipartFile = null; try { inputStream = ftpClient.retrieveFileStream(remoteFilePath); // 将FTP文件流换为字节数组输出流 outputStream = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len; while ((len = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, len); } // 将字节数组输出流换为字节数组 byte[] fileBytes = outputStream.toByteArray(); // 将字节数组换为MultipartFile对象 multipartFile = new MockMultipartFile(remoteFilePath, remoteFilePath.substring(remoteFilePath.lastIndexOf("/") + 1), "application/octet-stream", new ByteArrayInputStream(fileBytes)); } catch (IOException e) { e.printStackTrace(); throw new IOException("Convert failed!"); } finally { if (inputStream != null) { try { inputStream.close(); } catch (IOException e) { e.printStackTrace(); } } if (outputStream != null) { try { outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } if (ftpClient != null && inputStream != null && !ftpClient.completePendingCommand()) { ftpClient.logout(); ftpClient.disconnect(); } } return multipartFile; } } ``` 这个示例代码将FTPFile对象换为MultipartFile对象,首先获取FTPFile的流,并将其读取到字节数组中,然后通过`MockMultipartFile`对象封装成MultipartFile对象。要使用此方法,需要在类路径中添加`commons-net`和`spring-test`两个jar包。因为我们使用了`FTPClient`来读取远程文件流,同时也使用了`MockMultipartFile`来封装成MultipartFile对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值