JIOPi v0.3 建立了较为完善的本地模块化系统标准
说明:如未特殊说明,下文中的 JIOPi 均指 JIOPi v0.3 规范
JIOPi主题:蓝图!蓝图!
JIOPi v0.3 在继承了JIOPi v0.2 蓝图初现 的基础上,增加了本地模块化系统的全面支持,新增了以下特征和编程风格
- 模块间依赖的自动装配
- 模块使用方对模块的自定义配置式装配
- 符合Java风格的标准类库机制
- 配置文件特殊变量替换以允许模块使用持久或临时目录
- 所有配置文件允许在Context层替换
- 配置文件单例模式
- 接口注册允许注册为Java标准接口的实现
像工业化系统一样允许一个Java系统是由若干模块组合而成是JIOPi的重要思想和长远目标,为了实现这个目标,JIOPi制定了符合工业化模块装配模式的 装配说明文件,以及相应的非运行时程序注解(Annotation),并制定了兼容现有Java类库的CommonLib机制,下面将对相关配置和标准进行说明:
V0.2标注改进
对象实例化方式从原来的两种(单例,原型)增加为三种,新增的模式为 配置文件单例模式,即在使用相同配置文件进行对象请求时,JIOPi容器会返回相同的对象。
Blueprint类标注
@Target({ElementType.METHOD})
public @interface Socket
指定接口连接方法,在一个方法上加注该标注,即表示所有同名函数均为连接方法,连接方法至少应当有一个参数,为接受的插入对象的接口类型,可有若干String类型的参数,用于插入时的附加参数指定
连接方法可以认为是一个对象的插槽(Socket),当 将 b 对象 插入 a时,将尝试查找a上的所有允许 插入b的连接方法,如果找到,将调用该方法将b对象插入a中,因此如果b实现了多个接口,而a均允许这些接口的插入,则这些符合的接口函数均会被调用。插入是由装配文件进行说明的,将在稍后说明。
Socket方法举例:
public interface AA{
@Socket
public void socket(A a);
public void socket(B a);
public void socket(C a);
}
public class AAClass implements AA{}
public class ABCClass implements A,B,C{}
AA aa = new AAClass ();
ABCClass abc = new ABCClass();
如果将 abc对象插入aa对象,AA定义的三个方法将都被调用,但是传递的参数均为abc对象
Module类标注
@Target(ElementType.FIELD)
public @interface SocketModule
指定成员变量的依赖注入,无需set方法,使用反射机制直接注入,如果需要set,可将set方法注册为Socket方法,使用配置文件装配
String id() default ""; 内部零件ID,指定ID后将允许在装配文件中重定义装配模块
String module() default ""; 模块名
String version() default "";模块版本
String configuration() default "";装配模块时使用的配置ID
虽然默认值均为 "",但是为了保证程序的正确运行, module是应当被指定的,允许不被指定是因为在指定ID后这些都是可以在装配文件中重定义的。
模块版本除非必要,不应指定,将使用该成员变量接口的版本自动查找匹配的最新版本的实现类,如果指定,则必须与接口的版本兼容,否则以接口的版本为准,如接口版本为 1.0 则不可指定模块为2.0,1.0.1 是允许的
@Target(ElementType.FIELD)
public @interface SocketControlPanel
与SocketModule相似,只是SocketModule的成员变量必须是接口,而这个标注用于变量类型是JIOPi的接口类ControlPanel的依赖注入
String id() default "";
String module() default "";
String version() default "";
String controlpanel(); 使用的控制面板名(接口名)
String configuration() default "";
参数基本与SocketModule相同,多了一个 controlpanel,是因为前者可以根据变量的类型自动查找匹配的实现类,而这里必须制定
蓝图库
蓝图库增加CommonLib配置:
<commonlib group="main" base-url="commonlib/main/">
<resource>jiopi-main-commons-logging-1.1.1.jar</resource>
<resource>jiopi-main-log4j-1.2.16.jar</resource>
</commonlib>
一个蓝图库中可以有多个CommonLib组,分组是因为Jar依赖的问题,因此在一个组内的Jar必须不存在任何版本依赖问题
因为确定一个Jar是否为CommonLib以及属于哪个组的依据是文件名(减少配置文件个数),为了避免出现运行时问题,务必将放入不同组的Jar加上一个不同的前缀
装配文件
装配文件名必须为 jiopi-config.xml,应当放在模块Jar的跟目录,或ContextClassPath的根目录
<?xml version="1.0" encoding="UTF-8"?>
<configuration xmlns="http://www.jiopi.org/2010/JIOPISchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.jiopi.org/2010/JIOPISchema xsd/jiopi-config-configuration.xsd ">
<!--制定装配的模块名和版本,版本为兼容版本,装配时将使用最匹配的版本-->
<module name="voyager.benz.car_sls_amg" version="0.1">
<!--制定装配的接口名,当使用指定接口申请实现类时,将使用该装配-->
<controlpanel name="voyager.car">
<!--重定义内部依赖注入,ID为SocketModule标注上的ID-->
<inner-accessory id="engine" module="voyager.benz.engine_v8"/>
<!-- install ETASocket -->
<!--定义一个待装配的零件(对象),命名为id-->
<accessory id="etasocket" controlpanel="voyager.etasocket" module="voyager.common.etasocket_common" version="0.1"/>
<!--将etasocket零件连接到engine上
注意这里的连接是自动双向链接,即先调用 engine.socket(etasocket)
再调用etasocket.socket(engine)(如果存在的话),以实现连接后的相互知晓(如果需要的话)
-->
<socket from="etasocket" to="engine"/>
<!-- install axletree -->
<accessory id="axletree" controlpanel="voyager.axletree" module="voyager.benz.axletree_amg" version="0.1"/>
<socket from="axletree" to="etasocket"/>
<!-- install wheels -->
<accessory id="wheel" controlpanel="voyager.wheel" module="voyager.benz.wheel_amg" version="0.1" retrieve="true" />
<!--这里的socket增加了参数,是因为socket函数是这样定义的
public void socket(Wheel w,String id);
-->
<socket from="wheel" to="axletree"><arg><value>0</value></arg></socket>
<socket from="wheel" to="axletree"><arg><value>1</value></arg></socket>
<socket from="wheel" to="axletree"><arg><value>2</value></arg></socket>
<socket from="wheel" to="axletree"><arg><value>3</value></arg></socket>
</controlpanel>
</module>
</configuration>
级联式装配
级联式允许模块的装配文件被使用者替换,以实现配置式装配
级联式装配的覆盖路径是这样的:
Context--使用-->ModuleA--使用-->ModuleB
则在装配ModuleB时,Context中的jiopi-config.xml会覆盖ModuleA的,然后在覆盖ModuleB的
因此除非必须,不要覆盖默认的装配,应使用configuration_id定义新的装配定义,如下
<?xml version="1.0" encoding="UTF-8"?>
<configuration xmlns="http://www.jiopi.org/2010/JIOPISchema" xmlns:jiopi="http://www.jiopi.org/2010/JIOPISchema-configuration" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.jiopi.org/2010/JIOPISchema configuration/jiopi-config-configuration.xsd ">
<!--指定覆盖的模块和版本-->
<module name="voyager.benz.car_sls_amg" version="0.1">
<!--定义新的装配表,命名为v9,
jiopi:template-except="id" 用于说明使用 默认装配表作为模版进行覆盖
-->
<controlpanel name="voyager.car" id="v9" jiopi:template-except="id">
<!--覆盖指定项,
jiopi:replace-attribute 定义覆盖的是哪个属性
-->
<inner-accessory id="engine" module="voyager.benz.engine_v9" jiopi:replace-attribute="module"/>
<!--
jiopi:reset="true" 指定首先删除模版中所有同属性的配置,以重新定义,因为模版是4个轮子,这里只用2个
jiopi:replace-content="add"标记下面的属性直接插入,不用再次计算覆盖问题
-->
<socket from="wheel" to="axletree" jiopi:replace-content="add" jiopi:reset="true"><arg><value>0</value></arg></socket>
<socket from="wheel" to="axletree" jiopi:replace-content="add"><arg><value>1</value></arg></socket>
</controlpanel>
</module>
</configuration>
配置文件变量
由于模块编写者不知道其运行环境,当需要访问文件系统时,无法确认使用的路径,因此JIOPi提供了配置文件变量替换以允许模块编写者在指定路径下使用临时文件夹或持久性文件夹
配置文件变量分为 模块配置文件 和 CommonLib配置文件
模块配置文件的变量为
${module-dir} 和${module-temp-dir}
CommonLib配置文件的变量为
${common-dir} 和 ${common-temp-dir}
如可以写为 ${module-dir}/logs/car.log
temp文件夹会在JIOPi容器关闭时(主进程退出)被删除
${module-dir} 对应 ibean.work.dir/context/modulename-version/
${module-temp-dir} 对应 ibean.work.dir/context/temp/modulename-version/
${common-dir} 对应ibean.work.dir/context/common/poolname/group/
${common-temp-dir} 对应ibean.work.dir/context/temp/common/poolname/group/
总结
JIOPi V0.3定义了实现本地模块化系统相关的注解和配置,从而向模块的使用方屏蔽了该模块的装配细节,并提供了允许使用方重定义的配置式装配模式,为模块化系统提供了更加灵活的自由装配组合模型。
分享到:
相关推荐
ASP.NET网络进销存管理系统源码 内含一些新技术的使用,使用的是VS .NET 2008平台采用标准的三层架构设计,采用流行的AJAX技术 使操作更加流畅,统计报表使用FLASH插件美观大方专业。适合二次开发类似项目使用,可以节省您 开发项目周期,源码统计报表部分需要自己将正常功能注释掉的源码手工取消掉注释。这是我在调试程 序时留下的。也是上传源码前的疏忽。 您下载后可以用VS2008直接打开将注释取消掉即可正常使用。 技术特点:1、采用目前最流行的.net技术实现。2、采用B/S架构,三层无限量客户端。 3、配合SQLServer2005数据库支持 4、可实现跨越地域和城市间的系统应用。 5、二级审批机制,简单快速准确。 6、销售功能手写AJAX无刷新,快速稳定。 7、统计报表采用Flash插件美观大方。8、模板式开发,能够快速进行二次开发。权限、程序页面、 基础资料部分通过后台数据库直接维护,可单独拿出继续开发其他系统 9、数据字典,模块架构图,登录页面和主页的logo图片 分别放在DOC PSD 文件夹中
# 基于ZooKeeper的分布式服务管理系统 ## 项目简介 本项目是一个基于ZooKeeper的分布式服务管理系统,旨在通过ZooKeeper的协调服务功能,实现分布式环境下的服务注册、发现、配置管理以及分布式锁等功能。项目涵盖了从ZooKeeper的基本操作到实际应用场景的实现,如分布式锁、商品秒杀等。 ## 项目的主要特性和功能 1. 服务注册与发现通过ZooKeeper实现服务的动态注册与发现,支持服务的动态上下线。 2. 分布式锁利用ZooKeeper的临时顺序节点特性,实现高效的分布式锁机制,避免传统锁机制中的“羊群效应”。 3. 统一配置管理通过ZooKeeper集中管理分布式系统的配置信息,实现配置的动态更新和实时同步。 4. 商品秒杀系统结合分布式锁和ZooKeeper的监听机制,实现高并发的商品秒杀功能,确保库存的一致性和操作的原子性。 ## 安装使用步骤 1. 环境准备
23python3项目
技术资料分享AL422B很好的技术资料.zip
c语言俄罗斯方块
Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
delphi人才信息管理系统
安卓巴士总结了近百个Android优秀开源项
1.程序功能说明: MATLAB蒙特卡洛仿真计算投资组合的VaR(Value at Risk ) 根据协方差矩阵等参数先计算涨期权和看跌期权的价格,再采用蒙特卡洛模拟法计算该投资组合的VaR。 2.代码说明:注释清晰,参数和变量说明清晰,方便更改、方便初学者使用,模块化编程,方便替换目标函数。运行环境Windows7及以上操作系统,MATLAB2014a及以上版本。 3.适用专业:计算机、电子信息工程、数学、物理、机械工程、土木工程等专业的大学生、研究生毕业设计,各类专业的课程设计、海外留学生作业等。 4作者介绍:资深算法工程师, 从事Matlab、Python算法仿真工作15年,专业研究遗传算法、粒子群算法、蚁群算法、鲸鱼算法、狼群算法等. 有问题联系QQ: 1579325979
SpringBoot - Async异步处理
完全退出程序的方法
hutool.all操作excel的依赖包,一共18个jar包,懒得去排查包的可以直接下载直接导入使用;我用eclipse和ideal接导入外部jar包。亲测可用;如果工程里面有相同的jar包,保留版本号高的; commons-cli-1.0.jar commons-codec-1.15.jar commons-collections4-4.4.jar commons-compress-1.21.jar commons-io-2.11.0.jar commons-lang3-3.4.jar commons-logging-api-1.1.jar commons-math3-3.6.1.jar hutool-all-5.8.21.jar log4j-1.2.12.jar log4j-api-2.20.0.jar log4j-core-2.20.0.jar poi-5.2.3.jar poi-ooxml-5.2.3.jar ……
# 基于Python的微信签到管理系统 ## 项目简介 本项目是一个基于Python的微信签到管理系统,旨在通过微信自动收集和管理学生的宿舍签到信息。系统通过微信的群聊功能,自动识别并记录符合特定格式的签到信息,并将其存储在Excel表格中。该系统特别适用于学校或组织需要定期收集学生签到信息的场景。 ## 项目的主要特性和功能 1. 自动签到信息收集系统能够自动检测微信中大于三人的群聊,识别并记录符合特定格式的签到信息。 2. 灵活的签到格式支持自定义签到格式,通过正则表达式匹配签到信息,确保信息的准确性和一致性。 3. 自动生成签到表格每周自动生成新的签到表格,并根据开学周数计算当前学期的周数。 4. 转发补录功能支持通过转发信息的方式补录错过的签到信息,提高信息的完整性。 5. 路径和模板配置允许用户自定义签到表格的存储路径和模板信息,方便管理和维护。 ## 安装使用步骤 ### 1. 环境搭建
# 基于Arduino和OpenWeatherMap的天气LED显示系统 ## 项目简介 此项目是一个基于天气数据的LED显示系统,主要用于展示当前的天气状况。它使用了WiFi连接的Arduino和LED灯带,通过OpenWeatherMap提供的API获取天气数据。项目旨在提高技术技能和软技能模块的学习成果。 ## 项目的主要特性和功能 ### 天气数据的展示 实时天气展示系统可以展示不同的天气状况,如晴朗、多云、降雨、雷电、雾等。 地点设置用户可以通过Blynk应用设置想要展示的地点,并实时获取该地点的天气数据。 更新间隔设置用户还可以设置数据更新的时间间隔。 ### 动画展示功能 天气模拟动画系统具有动画展示功能,用户可以选择不同的动画模式,如天气模拟动画。 LED颜色变换支持单个LED灯的颜色变换以及色彩淡入淡出动画等。 自动切换动画模式可以手动选择或通过定时设置自动切换。 ## 安装和使用步骤
将jar文件转换为exe
tdm64-gcc-9.2.0是一个编译器,如果大家在安装truetime运行中无法直接下载官方的编译器,就参考配置方法文档用这个编译器 大家需要首先安装vc++,可参考安装VScode 2019 版本
SAE AS5756C-2021 中文.pdf
c语言实现水波纹显示效果
基于C语言的winform界面火车票订票系统项目资源
2024年企业竞争模拟大赛河南大学校赛的通知(1) (1).pdf