zoukankan      html  css  js  c++  java
  • spring初步

    1.强依赖关系

    public class JdbcDemo1 {
    
        public static void main(String[] args) throws SQLException, ClassNotFoundException {
            //1.注册驱动
          //  DriverManager.registerDriver(new com.mysql.jdbc.Driver());
            Class.forName("com.mysql.jdbc.Driver");
            //2.获取连接
            Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/guli","root","root");
            //3.获取操作数据库的预处理对象
            PreparedStatement pstm = conn.prepareStatement("select * from edu_chapter");
            //4.执行SQL,得到结果集
            ResultSet rs = pstm.executeQuery();
            //5.遍历结果集
            while (rs.next()) {
                System.out.println(rs.getString("title"));
            }
            //6.释放资源
            rs.close();
            pstm.close();
            conn.close();
        }
    }

    2.根据工厂模式读取配置内容创建单例对象例子

    public class AccountServiceImpl implements IAccountService {
    
    //    private IAccountDao accountDao = new AccountDaoImpl();
    
        private IAccountDao accountDao = (IAccountDao)BeanFactory.getBean("accountDao");
    
       //private int i = 1;
    
        public void  saveAccount(){
            int i = 1;
            accountDao.saveAccount();
            System.out.println(i);
            i++;
        }
    }
    /**
     * 一个创建Bean对象的工厂
     *
     * Bean:在计算机英语中,有可重用组件的含义。
     * JavaBean:用java语言编写的可重用组件。
     *      javabean >  实体类
     *
     *   它就是创建我们的service和dao对象的。
     *
     *   第一个:需要一个配置文件来配置我们的service和dao
     *           配置的内容:唯一标识=全限定类名(key=value)
     *   第二个:通过读取配置文件中配置的内容,反射创建对象
     *
     *   我的配置文件可以是xml也可以是properties
     */
    public class BeanFactory {
        //定义一个Properties对象
        private static Properties props;
    
        //定义一个Map,用于存放我们要创建的对象。我们把它称之为容器
        private static Map<String,Object> beans;
    
        //使用静态代码块为Properties对象赋值
        static {
            try {
                //实例化对象
                props = new Properties();
                //获取properties文件的流对象
                InputStream in = BeanFactory.class.getClassLoader().getResourceAsStream("bean.properties");
                props.load(in);
                //实例化容器
                beans = new HashMap<String,Object>();
                //取出配置文件中所有的Key
                Enumeration keys = props.keys();
                //遍历枚举
                while (keys.hasMoreElements()){
                    //取出每个Key
                    String key = keys.nextElement().toString();
                    //根据key获取value
                    String beanPath = props.getProperty(key);
                    //反射创建对象
                    Object value = Class.forName(beanPath).newInstance();
                    //把key和value存入容器中
                    beans.put(key,value);
                }
            }catch(Exception e){
                throw new ExceptionInInitializerError("初始化properties失败!");
            }
        }
    
        /**
         * 根据bean的名称获取对象
         * @param beanName
         * @return
         */
        public static Object getBean(String beanName){
            return beans.get(beanName);
        }

    bean.properties

    accountService=com.itheima.service.impl.AccountServiceImpl
    accountDao=com.itheima.dao.impl.AccountDaoImpl

    3.立即加载和延迟加载

    /**
     * 模拟一个表现层,用于调用业务层
     */
    public class Client {
    
        /**
         * 获取spring的Ioc核心容器,并根据id获取对象
         *
         * ApplicationContext的三个常用实现类:
         *      ClassPathXmlApplicationContext:它可以加载类路径下的配置文件,要求配置文件必须在类路径下。不在的话,加载不了。(更常用)
         *      FileSystemXmlApplicationContext:它可以加载磁盘任意路径下的配置文件(必须有访问权限)
         *      AnnotationConfigApplicationContext:它是用于读取注解创建容器的,是明天的内容。
         *
         * 核心容器的两个接口引发出的问题:
         *  ApplicationContext:     单例对象适用              采用此接口
         *      它在构建核心容器时,创建对象采取的策略是采用立即加载的方式。也就是说,只要一读取完配置文件马上就创建配置文件中配置的对象。
         *
         *  BeanFactory:            多例对象使用
         *      它在构建核心容器时,创建对象采取的策略是采用延迟加载的方式。也就是说,什么时候根据id获取对象了,什么时候才真正的创建对象。
         * @param args
         */
        public static void main(String[] args) {
            //1.获取核心容器对象
            ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
         //   ApplicationContext ac = new FileSystemXmlApplicationContext("C:\Users\zhy\Desktop\bean.xml");
            //2.根据id获取Bean对象
            IAccountService as  = (IAccountService)ac.getBean("accountService");
            IAccountDao adao = ac.getBean("accountDao",IAccountDao.class);
    
            System.out.println(as);
            System.out.println(adao);
            as.saveAccount();
    
    
            //--------BeanFactory----------
    //        Resource resource = new ClassPathResource("bean.xml");
    //        BeanFactory factory = new XmlBeanFactory(resource);
    //        IAccountService as1  = (IAccountService)factory.getBean("accountService");
    //        System.out.println(as1);
        }
    }

        <!-- bean对象的生命周期
                单例对象
                    出生:当容器创建时对象出生
                    活着:只要容器还在,对象一直活着
                    死亡:容器销毁,对象消亡
                    总结:单例对象的生命周期和容器相同
                多例对象
                    出生:当我们使用对象时spring框架为我们创建
                    活着:对象只要是在使用过程中就一直活着。
                    死亡:当对象长时间不用,且没有别的对象引用时,由Java的垃圾回收器回收
         -->
        <bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl"
              scope="prototype" init-method="init" destroy-method="destroy"></bean>
     <!-- bean的作用范围调整
            bean标签的scope属性:
                作用:用于指定bean的作用范围
                取值: 常用的就是单例的和多例的
                    singleton:单例的(默认值)
                    prototype:多例的
                    request:作用于web应用的请求范围
                    session:作用于web应用的会话范围
                    global-session:作用于集群环境的会话范围(全局会话范围),当不是集群环境时,它就是session
    
        <bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl" scope="prototype"></bean>
      <!--创建Bean的三种方式 -->
        <!-- 第一种方式:使用默认构造函数创建。
                在spring的配置文件中使用bean标签,配以id和class属性之后,且没有其他属性和标签时。
                采用的就是默认构造函数创建bean对象,此时如果类中没有默认构造函数,则对象无法创建。
    
        <bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl"></bean>
        -->
    
        <!-- 第二种方式: 使用普通工厂中的方法创建对象(使用某个类中的方法创建对象,并存入spring容器)
        <bean id="instanceFactory" class="com.itheima.factory.InstanceFactory"></bean>
        <bean id="accountService" factory-bean="instanceFactory" factory-method="getAccountService"></bean>
        -->
    
        <!-- 第三种方式:使用工厂中的静态方法创建对象(使用某个类中的静态方法创建对象,并存入spring容器)
        <bean id="accountService" class="com.itheima.factory.StaticFactory" factory-method="getAccountService"></bean>
        -->

    工厂类如下:

    /**
     * 模拟一个工厂类(该类可能是存在于jar包中的,我们无法通过修改源码的方式来提供默认构造函数)
     */
    public class InstanceFactory {
    
        public IAccountService getAccountService(){
            return new AccountServiceImpl();
        }
    }
    
    
    /**
     * 模拟一个工厂类(该类可能是存在于jar包中的,我们无法通过修改源码的方式来提供默认构造函数)
     */
    public class StaticFactory {
    
        public static IAccountService getAccountService(){
    
            return new AccountServiceImpl();
        }
    }

    4.依赖注入

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans.xsd">
    
        <!-- spring中的依赖注入
            依赖注入:
                Dependency Injection
            IOC的作用:
                降低程序间的耦合(依赖关系)
            依赖关系的管理:
                以后都交给spring来维护
            在当前类需要用到其他类的对象,由spring为我们提供,我们只需要在配置文件中说明
            依赖关系的维护:
                就称之为依赖注入。
             依赖注入:
                能注入的数据:有三类
                    基本类型和String
                    其他bean类型(在配置文件中或者注解配置过的bean)
                    复杂类型/集合类型
                 注入的方式:有三种
                    第一种:使用构造函数提供
                    第二种:使用set方法提供
                    第三种:使用注解提供(明天的内容)
         -->
    
    
        <!--构造函数注入:
            使用的标签:constructor-arg
            标签出现的位置:bean标签的内部
            标签中的属性
                type:用于指定要注入的数据的数据类型,该数据类型也是构造函数中某个或某些参数的类型
                index:用于指定要注入的数据给构造函数中指定索引位置的参数赋值。索引的位置是从0开始
                name:用于指定给构造函数中指定名称的参数赋值                                        常用的
                =============以上三个用于指定给构造函数中哪个参数赋值===============================
                value:用于提供基本类型和String类型的数据
                ref:用于指定其他的bean类型数据。它指的就是在spring的Ioc核心容器中出现过的bean对象
    
            优势:
                在获取bean对象时,注入数据是必须的操作,否则对象无法创建成功。
            弊端:
                改变了bean对象的实例化方式,使我们在创建对象时,如果用不到这些数据,也必须提供。
        -->
        <bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl">
            <constructor-arg name="name" value="泰斯特"></constructor-arg>
            <constructor-arg name="age" value="18"></constructor-arg>
            <constructor-arg name="birthday" ref="now"></constructor-arg>
        </bean>
    
        <!-- 配置一个日期对象 -->
        <bean id="now" class="java.util.Date"></bean>
    
        <!-- set方法注入                更常用的方式
            涉及的标签:property
            出现的位置:bean标签的内部
            标签的属性
                name:用于指定注入时所调用的set方法名称
                value:用于提供基本类型和String类型的数据
                ref:用于指定其他的bean类型数据。它指的就是在spring的Ioc核心容器中出现过的bean对象
            优势:
                创建对象时没有明确的限制,可以直接使用默认构造函数
            弊端:
                如果有某个成员必须有值,则获取对象是有可能set方法没有执行。
        -->
        <bean id="accountService2" class="com.itheima.service.impl.AccountServiceImpl2">
            <property name="name" value="TEST" ></property>
            <property name="age" value="21"></property>
            <property name="birthday" ref="now"></property>
        </bean>
    
    
        <!-- 复杂类型的注入/集合类型的注入
            用于给List结构集合注入的标签:
                list array set
            用于个Map结构集合注入的标签:
                map  props
            结构相同,标签可以互换
        -->
        <bean id="accountService3" class="com.itheima.service.impl.AccountServiceImpl3">
            <property name="myStrs">
                <set>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </set>
            </property>
    
            <property name="myList">
                <array>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </array>
            </property>
    
            <property name="mySet">
                <list>
                    <value>AAA</value>
                    <value>BBB</value>
                    <value>CCC</value>
                </list>
            </property>
    
            <property name="myMap">
                <props>
                    <prop key="testC">ccc</prop>
                    <prop key="testD">ddd</prop>
                </props>
            </property>
    
            <property name="myProps">
                <map>
                    <entry key="testA" value="aaa"></entry>
                    <entry key="testB">
                        <value>BBB</value>
                    </entry>
                </map>
            </property>
        </bean>
    
    </beans>

    5.使用注解ioc细节

    /**
     * 账户的业务层实现类
     *
     * 曾经XML的配置:
     *  <bean id="accountService" class="com.itheima.service.impl.AccountServiceImpl"
     *        scope=""  init-method="" destroy-method="">
     *      <property name=""  value="" | ref=""></property>
     *  </bean>
     *
     * 用于创建对象的
     *      他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的
     *      Component:
     *          作用:用于把当前类对象存入spring容器中
     *          属性:
     *              value:用于指定bean的id。当我们不写时,它的默认值是当前类名,且首字母改小写。
     *      Controller:一般用在表现层
     *      Service:一般用在业务层
     *      Repository:一般用在持久层
     *      以上三个注解他们的作用和属性与Component是一模一样。
     *      他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰
     *
     *
     * 用于注入数据的
     *      他们的作用就和在xml配置文件中的bean标签中写一个<property>标签的作用是一样的
     *      Autowired:
     *          作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
     *                如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。
     *                如果Ioc容器中有多个类型匹配时:
     *          出现位置:
     *              可以是变量上,也可以是方法上
     *          细节:
     *              在使用注解注入时,set方法就不是必须的了。
     *      Qualifier:
     *          作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入时不能单独使用。但是在给方法参数注入时可以(稍后我们讲)
     *          属性:
     *              value:用于指定注入bean的id。
     *      Resource
     *          作用:直接按照bean的id注入。它可以独立使用
     *          属性:
     *              name:用于指定bean的id。
     *      以上三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现。
     *      另外,集合类型的注入只能通过XML来实现。
     *
     *      Value
     *          作用:用于注入基本类型和String类型的数据
     *          属性:
     *              value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
     *                      SpEL的写法:${表达式}
     *
     * 用于改变作用范围的
     *      他们的作用就和在bean标签中使用scope属性实现的功能是一样的
     *      Scope
     *          作用:用于指定bean的作用范围
     *          属性:
     *              value:指定范围的取值。常用取值:singleton prototype
     *
     * 和生命周期相关 了解
     *      他们的作用就和在bean标签中使用init-method和destroy-methode的作用是一样的
     *      PreDestroy
     *          作用:用于指定销毁方法
     *      PostConstruct
     *          作用:用于指定初始化方法
     */
    @Service("accountService")
    @Scope("prototype")
    public class AccountServiceImpl implements IAccountService {
    
       @Autowired
       @Qualifier("accountDao2")
      //  @Resource(name = "accountDao2")
        private IAccountDao accountDao = null;
    
        @PostConstruct
        public void  init(){
            System.out.println("初始化方法执行了");
        }
    
        @PreDestroy
        public void  destroy(){
            System.out.println("销毁方法执行了");
        }
    
        public void  saveAccount(){
            accountDao.saveAccount();
        }
    }
    /**
     * 账户的持久层实现类
     */
    @Repository("accountDao1")
    public class AccountDaoImpl implements IAccountDao
    
        {
    
        public  void saveAccount(){
    
            System.out.println("保存了账户1111111111111");
        }
    }
    
    /**
     * 账户的持久层实现类
     */
    @Repository("accountDao2")
    public class AccountDaoImpl2  implements IAccountDao {
    
        public  void saveAccount(){
    
            System.out.println("保存了账户2222222222222");
        }
    }

  • 相关阅读:
    C# Timer用法及实例详解
    c#使用MethodInvoker解决跨线程访问控件
    C# 网络通信大小端转换类
    c# 高效的线程安全队列ConcurrentQueue(下) Segment类
    OPTIMIZE TABLE
    TRUNCATE TABLE 与 DELETE table 区别
    mysql 优化
    linux 内核---------董昊 ( Robin Dong ) and OenHan
    Linux内核分析:页回收导致的cpu load瞬间飙高的问题分析与思考--------------蘑菇街技术博客
    google perftools分析程序性能
  • 原文地址:https://www.cnblogs.com/liuyi13535496566/p/13564518.html
Copyright © 2011-2022 走看看