zoukankan      html  css  js  c++  java
  • 单例多例以及全局局部

    单例多例需要搞明白两个问题:

    1. 什么是单例多例;
    2. 如何产生单例多例;
    3. 为什么要用单例多例
    4. 什么时候用单例,什么时候用多例;

    1. 什么是单例多例:
      所谓单例就是所有的请求都用一个对象来处理,比如我们常用的service和dao层的对象通常都是单例的,而多例则指每个请求用一个新的对象来处理,比如action;
      Spring MVC Controller默认是单例的:
      最佳实践:
      1.不要再controller中定义成员变量。
      2.外衣必须要定义一个非静态成员变量的时候,他哦你过高注解@scopr("prototype")将其设为多例模式
      from:http://lavasoft.blog.51cto.com/62575/1394669/

    1. 如何产生单例多例:
      在通用的SSH中,单例在spring中是默认的,如果要产生多例,则在配置文件的bean中添加scope="prototype";
      根据经验,对有状态的bean应该使用prototype作用域,而对无状态的bean则应该使用singleton作用域。
      spring bean作用域有以下5个:
      singleton:单例模式,当spring创建applicationContext容器的时候,spring会欲初始化所有的该作用域实例,加上lazy-init就可以避免预处理;
      prototype:原型模式,每次通过getBean获取该bean就会新产生一个实例,创建后spring将不再对其管理;
      //以下在web中
      request:搞web的大家都应该明白request的域了吧,就是每次请求都新产生一个实例,和prototype不同就是创建后,接下来的管理,spring依然在监听;
      session:每次会话,同上;
      global session:全局的web域,类似于servlet中的application

    1. 为什么用单例多例:
      之所以用单例,是因为没必要每个请求都新建一个对象,这样子既浪费CPU又浪费内存;
      之所以用多例,是为了防止并发问题;即一个请求改变了对象的状态,此时对象又处理另一个请求,而之前请求对对象状态的改变导致了对象对另一个请求做了错误的处理;
      用单例和多例的标准只有一个:
      当对象含有可改变的状态时(更精确的说就是在实际应用中该状态会改变),则多例,否则单例;

    1. 何时用单例?何时用多例?
      对于struts2来说,action必须用多例,因为action本身含有请求参数的值,即可改变的状态;
      而对于STRUTS1来说,action则可用单例,因为请求参数的值是放在actionForm中,而非action中的;
      另外要说一下,并不是说service或dao一定是单例,标准同第3点所讲的,就曾见过有的service中也包含了可改变的状态,同时执行方法也依赖该状态,但一样用的单例,这样就会出现隐藏的BUG,而并发的BUG通常很难重现和查找;

    以上整理自:问答当中


    全局和局部变量

    static和非static


    线程安全和非线程安全
    blog:
    http://blog.csdn.net/ghsau/article/details/7421217
    http://blog.csdn.net/ghsau/article/details/7433673


    1.web应用中,要对某一个任务用多线程实现,最简单的代码格式是不是必须把要执行的代码放在run方法中?
    WEB服务器会帮你把每个访问请求开辟一个线程,你只要按照你所开发的框架,比如tomcat会让你利用servlet这个框架来写代码。具体真的一言难尽,反正不用写到RUN中,除非你想对线程控制到极致,例如你要做测试。


    2.部署在服务器上的一个网站,多个浏览器在访问同一个功能点时,存在多线程之说吗?
    多个浏览器的意思如果是(无论多台电脑上还是同一台电脑上的)多个页面打开同一网站的某个功能页面,那么如第一个问题所说,每一次访问(即打开页面)都是一个请求,服务器会为每个请求开辟一个线程,就是多线程。

    3.多线程和并发之间是怎么一种关系?
    多线程执行效率就是评判并发效果的好坏,高并发的概念就是在保证数据准确的情况下,减少进程所需操作的时间,特别经典的是页面访问服务器后,让服务器去修改数据库,如果你的数据库优化做的到位,那么查找数据并返回给客户端的时间将大大减少,我们知道对于一个热门网站的查询量是非常大的,然后一个服务器内存可以接收的进程数量也是有限的,这样一来,我们就说某一时间段内处理线程(访问请求)越多,那么并发效率就越好了。

    4.对于经典的买票程序,是因为要操作共同资源而是用多线程技术,那么对于一些平常的查询显示功能就没必要用多线程技术。对于这里发起的多个查询请求,是多个线程吗?
    买票程序应用与WEB就应该是多线程,共同资源存放在数据库中,和第三个问题的回答类似,这种商业性的站点更侧重于保证数据准确性,有时候我们修改的某项值会影响到别人的查询与增删,于是意外情况就产生了,例如在一个A线程(用户)正在修改某项值(买票)的情况下,要减少1张的剩余票总量是不准确的,因为当这个用户在方法中对获得的总剩余票数的同时(以获得总剩余票数,但还未减一),另一个B线程(用户)也进行买票,那么B获得的总剩余票数与A是相同的,因此他们如果同时被允许操作数据库的公共资源,那么当两人都只想完购票的减一操作时,第三线程或其他线程的查询剩余票量将只会看到原本减少2张剩余量,实际只少了一张,可以想象如果操作的线程越多,误差将会更大。因此数据库才会有事务,锁等等概念来提高确保数据准确性前提下的并发效率

    你以为躲起来就找不到你了吗?没有用的!象你这样出色的男人,无论在什么地方,都像漆黑中的萤火虫一样,那样的鲜明,那样的出众。你那忧郁的眼神,稀嘘的胡喳子,神乎其神的刀法,和那杯Dry Martine,都深深地迷住了我!
  • 相关阅读:
    每天一道LeetCode--141.Linked List Cycle(链表环问题)
    每天一道LeetCode--119.Pascal's Triangle II(杨辉三角)
    每天一道LeetCode--118. Pascal's Triangle(杨辉三角)
    CF1277D Let's Play the Words?
    CF1281B Azamon Web Services
    CF1197D Yet Another Subarray Problem
    CF1237D Balanced Playlist
    CF1239A Ivan the Fool and the Probability Theory
    CF1223D Sequence Sorting
    CF1228D Complete Tripartite
  • 原文地址:https://www.cnblogs.com/wjjFJ/p/5262873.html
Copyright © 2011-2022 走看看