hibernate annoation (一加载)

本文详细介绍了Hibernate中配置文件的不同加载方式,包括通过类路径、URL、文件路径等方法,并解释了内部实现机制。

转载请说明地址和作者

 

一,配置文件加载

 1,Configuration

       如果不是annoation则可以使用Configuration configuration = new Configuration();

       使用annoation则可以使用Configuration configuration = new AnnotationConfiguration();

  2,加载,使用onfiguration的configure方法根据方法参数可以有一下几种加载方式:

       (1) configure();

             吃方法会去classpath下寻找我们的配置文件

             其实调用了configure( "/hibernate.cfg.xml" );也就是 configure(String resource);方法

       (2) configure(String resource);

             最常用方的方法,其实调用了doConfigure(InputStream stream, String resourceName);

            

             说明一点内部代码:

             ConfigHelper.getResourceAsStream( resource );

           

		String stripped = resource.startsWith("/") ?
				resource.substring(1) : resource;

		InputStream stream = null;
		ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
		if (classLoader!=null) {
			stream = classLoader.getResourceAsStream( stripped );
		}
		if ( stream == null ) {
			stream = Environment.class.getResourceAsStream( resource );
		}
		if ( stream == null ) {
			stream = Environment.class.getClassLoader().getResourceAsStream( stripped );
		}
		if ( stream == null ) {
			throw new HibernateException( resource + " not found" );
		}
		return stream;
	

       第一行高数我们"/hibernate.cfg.xml" 可以去掉前面的“/”其中调用了Thread.currentThread().getContextClassLoader();一般也就是我们的AppClassLoader

     由stream = Environment.class.getResourceAsStream( resource );可以看出我们的"/hibernate.cfg.xml同样可以放在与和Environment同样的目录 具体到我们的代码里面在使用(3),(4),(5)时可以放在加载 类的包内或其他

       (3) configure(URL url);

        doConfigure( url.openStream(), url.toString() );调用(5)

       (4) configure(File configFile);

         doConfigure( new FileInputStream( configFile ), configFile.toString() );调用(5)

       (5) doConfigure(InputStream stream, String resourceName);

          使用dom4j解析文件为Document然后

           xmlHelper.createSAXReader( resourceName, errors, entityResolver )
     .read( new InputSource( stream ) );

                         掉用(6)

       (6) configure(Document document);

       在这个方法里会解析所有配置信息和mapping类或者hb文件

 

      

【事件触发致性】研究多智能体网络如何通过分布式事件驱动控制实现有限时间内的共识(Matlab代码实现)内容概要:本文围绕多智能体网络中的事件触发致性问题,研究如何通过分布式事件驱动控制实现有限时间内的共识,并提供了相应的Matlab代码实现方案。文中探讨了事件触发机制在降低通信负担、提升系统效率方面的优势,重点分析了多智能体系统在有限时间收敛的致性控制策略,涉及系统模型构建、触发条件设计、稳定性与收敛性分析等核心技术环节。此外,文档还展示了该技术在航空航天、电力系统、机器人协同、无人机编队等多个前沿领域的潜在应用,体现了其跨学科的研究价值和工程实用性。; 适合人群:具备定控制理论基础和Matlab编程能力的研究生、科研人员及从事自动化、智能系统、多智能体协同控制等相关领域的工程技术人员。; 使用场景及目标:①用于理解和实现多智能体系统在有限时间内达成致的分布式控制方法;②为事件触发控制、分布式优化、协同控制等课题提供算法设计与仿真验证的技术参考;③支撑科研项目开发、学术论文复现及工程原型系统搭建; 阅读建议:建议结合文中提供的Matlab代码进行实践操作,重点关注事件触发条件的设计逻辑与系统收敛性证明之间的关系,同时可延伸至其他应用场景进行二次开发与性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值