Castle IOC容器实践之TypedFactory Facility(一)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:
摘要:相信大家对于Factory Method设计模式都已经不陌生了,在Factory Method中,对于每一个具体的产品都需要有一个与之对应的工厂类,随着具体的产品越来越多,我们对于工厂类的管理就越来越困难,那如何通过IOC容器来实现对工厂的管理呢?本文将给你答案,通过TypedFactory Facility来实现。
 
主要内容
1 TypedFactory Facility概述
2 TypedFactory Facility快速入门
 
一.TypedFactory Facility概述
相信大家对于Factory Method设计模式都已经不陌生了,在Factory Method中,对于每一个具体的产品都需要有一个与之对应的工厂类,随着具体的产品越来越多,我们对于工厂类的管理就越来越困难,那如何通过IOC容器来实现对工厂的管理呢?本文将给你答案。在开始使用之前,我们还是先来看一下Castle官方网站中给出的有关TypedFactory Facility的信息:
Facility Information
Uses proxy
Yes
Requires configuration
Yes
Uses attributes
No
Version
Beta 2
二.TypedFactory Facility快速入门
1 .创建产品接口
 

/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   interface  IProduct
{
    
void Display();
}

2 .定义多个具体的产品,实现于接口Iproduct
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   class  ConcreteProductA : IProduct
{
    
public void Display()

    
{

        Console.WriteLine(
"ConcreteProductA");

    }

}
 
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   class  ConcreteProductB : IProduct
{
    
public void Display()
    
{
        Console.WriteLine(
"ConcreteProductB");

    }

}
 
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   class  ConcreteProductC : IProduct
{
    
public void Display()
    
{
        Console.WriteLine(
"ConcreteProductC");
    }

}

3
.定义工厂接口
在工厂接口中,只有一个方法Create()
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   interface  IFactory
{
    
// 创建方法

    IProduct Create(
string id);
}

当然了我们也可以为组件加上一个释放的方法 Release()
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   interface  IFactory
{
    
// 创建方法
    IProduct Create(string id);


    
// 销毁方法
    void Release(IProduct handler);
}

4 .创建配置文件
在开始的Facility信息中,可以看到TypedFactory Facility是需要配置信息
<!-- /* 

    Author:Terrylee

    Date:2006年5月12日

    From:[url]http://terrylee.cnblogs.com[/url]

*/
-->

<? xml version="1.0" encoding="utf-8"  ?>  

< configuration >

    
< facilities >

        
< facility  id ="typedfactory" >

            
< factories >

                
< factory  id ="factory"  interface ="TypedFactoryFacilityDemo.IFactory, TypedFactoryFacilityDemo"

                    creation
="Create"  destruction ="Release"   />

            
</ factories >

        
</ facility >

    
</ facilities >

</ configuration >

5 .使用TypedFactory Facility
有了前面几步的准备,现在就可以使用了,只需要注册Facility就可以了,容器会自动根据配置信息来注册工厂类的实现
/// <summary>

/// Author:Terrylee

/// Date:2006年5月12日

/// From:[url]http://terrylee.cnblogs.com[/url]

/// </summary>


public   class  App
{
    
public static void Main()
    
{
        
// 初始化容器

        IWindsorContainer container 
= new WindsorContainer(new XmlInterpreter("../../MyConfig.xml") );


        
// 加入TypedFactory Facility

        container.AddFacility( 
"typedfactory"new TypedFactoryFacility() );

 
        
// 加入具体产品

        container.AddComponent( 
"proda"typeof(IProduct), typeof(ConcreteProductA) );

        container.AddComponent( 
"prodb"typeof(IProduct), typeof(ConcreteProductB) );

        container.AddComponent( 
"prodc"typeof(IProduct), typeof(ConcreteProductC) );

        
        
// 获取工厂实例

        IFactory factory 
= (IFactory)container["factory"];

        
        
// 使用具体产品

        IProduct pa 
= factory.Create("proda");

        pa.Display();


        IProduct pb 
= factory.Create("prodb");

        pb.Display();


        IProduct pc 
= factory.Create("prodc");

        pc.Display();


        Console.ReadLine();
    }

}

完整的 TypedFactory Facility使用过程就是这样的,可以看到,从始至终在程序中只出现了一个工厂类的接口,并没有为每一个具体的产品创建一个工厂类,但是最后我们却可以像使用具体工厂类那样使用工厂的实例。同时,如果我们需要再新增一个新的产品就非常简单了。在这里还需要注意的一点就是在获取工厂的实例时所用到的 Key应该是在配置文件中 <factory>节点中配置的工厂 ID,而不能是 FacilityID!本篇文章就到这里,下一篇我会介绍 TypedFactory Facility的实现原理,希望感兴趣的朋友关注!







本文转自lihuijun51CTO博客,原文链接: http://blog.51cto.com/terrylee/67687 ,如需转载请自行联系原作者




相关文章
|
8月前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
326 2
|
2月前
|
XML Java 数据格式
Spring IoC容器的设计与实现
Spring 是一个功能强大且模块化的 Java 开发框架,其核心架构围绕 IoC 容器、AOP、数据访问与集成、Web 层支持等展开。其中,`BeanFactory` 和 `ApplicationContext` 是 Spring 容器的核心组件,分别定位为基础容器和高级容器,前者提供轻量级的 Bean 管理,后者扩展了事件发布、国际化等功能。
|
4月前
|
Ubuntu 关系型数据库 MySQL
容器技术实践:在Ubuntu上使用Docker安装MySQL的步骤。
通过以上的操作,你已经步入了Docker和MySQL的世界,享受了容器技术给你带来的便利。这个旅程中你可能会遇到各种挑战,但是只要你沿着我们划定的路线行进,你就一定可以达到目的地。这就是Ubuntu、Docker和MySQL的灵魂所在,它们为你开辟了一条通往新探索的道路,带你亲身感受到了技术的力量。欢迎在Ubuntu的广阔大海中探索,用Docker技术引领你的航行,随时准备感受新技术带来的震撼和乐趣。
195 16
|
5月前
|
监控 Kubernetes Cloud Native
基于阿里云容器服务Kubernetes版(ACK)的微服务架构设计与实践
本文介绍了如何基于阿里云容器服务Kubernetes版(ACK)设计和实现微服务架构。首先概述了微服务架构的优势与挑战,如模块化、可扩展性及技术多样性。接着详细描述了ACK的核心功能,包括集群管理、应用管理、网络与安全、监控与日志等。在设计基于ACK的微服务架构时,需考虑服务拆分、通信、发现与负载均衡、配置管理、监控与日志以及CI/CD等方面。通过一个电商应用案例,展示了用户服务、商品服务、订单服务和支付服务的具体部署步骤。最后总结了ACK为微服务架构提供的强大支持,帮助应对各种挑战,构建高效可靠的云原生应用。
|
5月前
|
监控 Cloud Native Java
基于阿里云容器服务(ACK)的微服务架构设计与实践
本文介绍如何利用阿里云容器服务Kubernetes版(ACK)构建高可用、可扩展的微服务架构。通过电商平台案例,展示基于Java(Spring Boot)、Docker、Nacos等技术的开发、容器化、部署流程,涵盖服务注册、API网关、监控日志及性能优化实践,帮助企业实现云原生转型。
|
7月前
|
人工智能 运维 监控
阿里云ACK容器服务生产级可观测体系建设实践
本文整理自2024云栖大会冯诗淳(花名:行疾)的演讲,介绍了阿里云容器服务团队在生产级可观测体系建设方面的实践。冯诗淳详细阐述了容器化架构带来的挑战及解决方案,强调了可观测性对于构建稳健运维体系的重要性。文中提到,阿里云作为亚洲唯一蝉联全球领导者的容器管理平台,其可观测能力在多项关键评测中表现优异,支持AI、容器网络、存储等多个场景的高级容器可观测能力。此外,还介绍了阿里云容器服务在多云管理、成本优化等方面的最新进展,以及即将推出的ACK AI助手2.0,旨在通过智能引擎和专家诊断经验,简化异常数据查找,缩短故障响应时间。
阿里云ACK容器服务生产级可观测体系建设实践
|
7月前
|
存储 人工智能 调度
容器服务:智算时代云原生操作系统及月之暗面Kimi、深势科技实践分享
容器技术已经发展成为云计算操作系统的关键组成部分,向下高效调度多样化异构算力,向上提供统一编程接口,支持多样化工作负载。阿里云容器服务在2024年巴黎奥运会中提供了稳定高效的云上支持,实现了子弹时间特效等创新应用。此外,容器技术还带来了弹性、普惠的计算能力升级,如每分钟创建1万Pod和秒级CPU资源热变配,以及针对大数据与AI应用的弹性临时盘和跨可用区云盘等高性能存储解决方案。智能运维方面,推出了即时弹性节点池、智能应用弹性策略和可信赖集群托管运维等功能,进一步简化了集群管理和优化了资源利用率。
|
7月前
|
运维 Kubernetes 调度
阿里云容器服务 ACK One 分布式云容器企业落地实践
阿里云容器服务ACK提供强大的产品能力,支持弹性、调度、可观测、成本治理和安全合规。针对拥有IDC或三方资源的企业,ACK One分布式云容器平台能够有效解决资源管理、多云多集群管理及边缘计算等挑战,实现云上云下统一管理,提升业务效率与稳定性。
|
7月前
|
人工智能 Cloud Native 调度
阿里云容器服务在AI智算场景的创新与实践
本文源自张凯在2024云栖大会的演讲,介绍了阿里云容器服务在AI智算领域的创新与实践。从2018年推出首个开源GPU容器共享调度方案至今,阿里云容器服务不断推进云原生AI的发展,包括增强GPU可观测性、实现多集群跨地域统一调度、优化大模型推理引擎部署、提供灵活的弹性伸缩策略等,旨在为客户提供高效、低成本的云原生AI解决方案。
|
8月前
|
安全 持续交付 Docker
深入理解并实践容器化技术——Docker 深度解析
深入理解并实践容器化技术——Docker 深度解析
241 2