精华内容
下载资源
问答
  • Spring框架里容器对象有哪些
    千次阅读
    2018-11-10 15:02:03

    Spring框架里容器对象有哪些?

    一、Spring BeanFactory 容器

    这是一个最简单的容器,它主要的功能是为依赖注入 (DI) 提供支持,这个容器接口在 org.springframework.beans.factory.BeanFactory 中被定义。

    二、Spring ApplicationContext 容器

    1、ApplicationContext容器简介:

    Application Context 是 spring 中较高级的容器。和 BeanFactory 类似,它可以加载配置文件中定义的 bean,将所有的 bean 集中在一起,当有请求的时候分配 bean。 另外,它增加了企业所需要的功能,比如,从属性文件中解析文本信息和将事件传递给所指定的监听器。这个容器在 org.springframework.context.ApplicationContext interface 接口中定义。

    ApplicationContext 包含 BeanFactory 所有的功能,一般情况下,相对于 BeanFactory,ApplicationContext 会被推荐使用。

     

    2、最常被使用的 ApplicationContext 接口实现:

    a :FileSystemXmlApplicationContext:

    该容器从 XML 文件中加载已被定义的 bean。在这里,你需要提供给构造器 XML 文件的完整路径

    b : ClassPathXmlApplicationContext

    该容器从 XML 文件中加载已被定义的 bean。在这里,你不需要提供 XML 文件的完整路径,只需正确配置 CLASSPATH 环境变量即可,因为,容器会从 CLASSPATH 中搜索 bean 配置文件。

    c : WebXmlApplicationContext

    该容器会在一个 web 应用程序的范围内加载在 XML 文件中已被定义的 bean。

    Spring框架文档地址: 

    https://docs.spring.io/spring/docs/current/spring-framework-reference/

    更多相关内容
  • Java容器哪些哪些是同步容器,哪些是并发容器? 一、基本概念 容器集 同步容器 并发容器 二、Collection集合接口 List接口 LinkedList类 ArrayList类 Vector类 Stack类 Set接口 HashSet类 TreeSet 三、Map集合...

    Java容器有哪些?哪些是同步容器,哪些是并发容器?
    一、基本概念
    容器集
    同步容器
    并发容器
    二、Collection集合接口
    List接口
    LinkedList类
    ArrayList类
    Vector类
    Stack类
    Set接口
    HashSet类
    TreeSet
    三、Map集合接口
    Hashtable类
    HashMap类
    HashTable和HashMap区别
    WeakHashMap类
    一、基本概念
    Java容器类类库的用途是“持有对象”,并将其划分为两个不同的概念:

    Collection:一个独立元素的序列,这些元素都服从一条或者多条规则。 List必须按照插入的顺序保存元素,而set不能有重复的元素。Queue按照排队规则来确定对象产生的顺序(通常与它们被插入的顺序相同)。
    Map:一组成对的“键值对”对象,允许你使用键来查找值。
    注:
    1、java.util.Collection是一个集合接口。
    它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java类库中有很多具体的实现。Collection接口的意义是为各种具体的集合提供了最大化的统一操作方式。

    2、java.util.Collections是一个包装类。
    它包含有各种有关集合操作的静态多态方法。此类不能实例化,就像一个工具类,服务于Java的Collection框架。

    容器集
    |Collection
    |  ├List
    |  │-├LinkedList
    |  │-├ArrayList
    |  │-└Vector
    |  │ └Stack
    |  ├Set
    |  │├HashSet
    |  │├TreeSet
    |  │└LinkedSet
    |
    |Map
      ├Hashtable
      ├HashMap
      └WeakHashMap

    同步容器
    Vector
    Stack
    HashTable
    Collections.synchronized方法生成
    并发容器
    ConcurrentHashMap:线程安全的HashMap的实现
    CopyOnWriteArrayList:线程安全且在读操作时无锁的ArrayList
    CopyOnWriteArraySet:基于CopyOnWriteArrayList,不添加重复元素
    ArrayBlockingQueue:基于数组、先进先出、线程安全,可实现指定时间的阻塞读写,并且容量可以限制
    LinkedBlockingQueue:基于链表实现,读写各用一把锁,在高并发读写操作都多的情况下,性能优于ArrayBlockingQueue
    二、Collection集合接口
    Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements)。一些Collection允许相同的元素而另一些不行。一些能排序而另一些不行。JavaSDK不提供直接继承自Collection的类,JavaSDK提供的类都是继承自Collection的“子接口”如List和Set。

    主要方法:
    boolean add(Object o)添加对象到集合
    boolean remove(Object o)删除指定的对象
    int size()返回当前集合中元素的数量
    boolean contains(Object o)查找集合中是否有指定的对象
    boolean isEmpty()判断集合是否为空
    Iterator iterator()返回一个迭代器
    boolean containsAll(Collection c)查找集合中是否有集合c中的元素
    boolean addAll(Collection c)将集合c中所有的元素添加给该集合
    void clear()删除集合中所有元素
    void removeAll(Collection c)从集合中删除c集合中也有的元素
    void retainAll(Collection c)从集合中删除集合c中不包含的元素

    List接口
    List是有序的Collection,使用此接口能够精确的控制每个元素插入的位置。用户能够使用索引(元素在List中的位置,类似于数组下标)来访问List中的元素,这类似于Java的数组。
       实现List接口的常用类有LinkedList,ArrayList,Vector和Stack。

    LinkedList类
    LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。
       注意:LinkedList是非同步的。如果多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建List时构造一个同步的List:

    List list = Collections.synchronizedList(new LinkedList(…));
    

    ArrayList类
    ArrayList实现了可变大小的数组。它允许所有元素,包括null。ArrayList没有同步。size,isEmpty,get,set方法运行时间为常数。但是add方法开销为分摊的常数,添加n个元素需要O(n)的时间。其他的方法运行时间为线性。每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。
       和LinkedList一样,ArrayList也是非同步的(unsynchronized)。一般情况下使用这两个就可以了,因为非同步,所以效率比较高。
       如果涉及到堆栈,队列等操作,应该考虑用List,对于需要快速插入,删除元素,应该使用LinkedList,如果需要快速随机访问元素,应该使用ArrayList。

    Vector类
    Vector非常类似ArrayList,但是Vector是同步的。由Vector创建的Iterator,虽然和ArrayList创建的Iterator是同一接口,但是,因为Vector是同步的,当一个Iterator被创建而且正在被使用,另一个线程改变了Vector的状态(例如,添加或删除了一些元素),这时调用Iterator的方法时将抛出ConcurrentModificationException,因此必须捕获该 异常。
      vector的使用主要有如下两种场景:
    (1)vector所谓的多线程安全,只是针对单纯地调用某个方法它是有同步机制的。如add,多个线程都在对同一个容器add元素,vector能够保证最后总数是正确的,而ArrayList没有同步机制,就无法保证。
    (2)vector的多线程安全,在组合操作时不是线程安全的。比如一个线程先调用vector的size方法得到有10个元素,再调用get(9)方法获取最后一个元素,而另一个线程调用remove(9)方法正好删除了这个元素,那第一个线程就会抛越界异常。
    总结:
    (1)在需要对容器进行组合操作时,vector不适用(需要自己用synchronized将组合操作进行同步);
    (2)仅在上述第一种场景时,才需要使用vector

    public class TestMultiThread {
    	private static Vector vec = new Vector();
    	private static List lst = new ArrayList();
    	public void f() {
    		TestThread testThread1 = new TestThread();
    		TestThread testThread2 = new TestThread();
    		Thread thread1 = new Thread(testThread1);
    		Thread thread2 = new Thread(testThread2);
    		thread1.start();
    		thread2.start();
    		}	
    	public static void main(String[] args) {
    		TestMultiThread testMultiThread = new TestMultiThread();
    		testMultiThread.f();
    		try {
    			Thread.sleep(5000);
    		} catch (InterruptedException e) {
    			e.printStackTrace();
    		}
    		System.out.println("vec size is " + vec.size());
    		System.out.println("lst size is " + lst.size());
    	}
    	private class TestThread implements Runnable {
    		@Override
    		public void run() {
    			for (int i = 0; i < 1000; ++i) {
    				vec.add(i);
    				lst.add(i);
    			}	
    		}		
    	}
    	private static Vector vec = new Vector();
    	private static List lst = new ArrayList();
    	public void f() {
    		    TestThread testThread1 = new TestThread();
    		    TestThread testThread2 = new TestThread();
    		    Thread thread1 = new Thread(testThread1);
    		    Thread thread2 = new Thread(testThread2);
    		    thread1.start();
    		    thread2.start();
    	} 
    }  
    

    如上程序运行结果:

    vec size is 2000
    lst size is 1999
    

    Stack类
    Stack继承自Vector,实现一个后进先出的堆栈。Stack提供5个额外的方法使得Vector得以被当作堆栈使用。基本的push和pop方法,还有
    peek方法得到栈顶的元素,empty方法测试堆栈是否为空,search方法检测一个元素在堆栈中的位置。Stack刚创建后是空栈。

    Set接口
    Set是一种不包含重复的元素的Collection,即任意的两个元素e1和e2都有e1.equals(e2)=false,Set最多有一个null元素。Set的构造函数有一个约束条件,传入的Collection参数不能包含重复的元素。
      Set容器类主要有HashSet和TreeSet等。

    HashSet类
    Java.util.HashSet类实现了Java.util.Set接口。

    它不允许出现重复元素;
    不保证集合中元素的顺序
    允许包含值为null的元素,但最多只能有一个null元素。

    public class TestHashSet
    {
      public static void main(String [] args)
      {
         HashSet h=new HashSet();
         h.add("1st");
         h.add("2nd");
         h.add(new Integer(3));
         h.add(new Double(4.0));
         h.add("2nd");            //重复元素,未被添加
         h.add(new Integer(3));      //重复元素,未被添加
         h.add(new Date());
         System.out.println("开始:size="+h.size());
         Iterator it=h.iterator();
         while(it.hasNext())
         {
             Object o=it.next();
             System.out.println(o);
         }
    
         h.remove("2nd");
         System.out.println("移除元素后:size="+h.size());
         System.out.println(h);
      }
    }
    

    TreeSet
    TreeSet描述的是Set的一种变体——可以实现排序等功能的集合,它在讲对象元素添加到集合中时会自动按照某种比较规则将其插入到有序的对象序列中,并保证该集合元素组成的读优先序列时刻按照“升序”排列。

    public class TestTreeSet
    {
        public static void main(String [] args)
        {
           TreeSet ts=new TreeSet();
           ts.add("orange");
           ts.add("apple");
           ts.add("banana");
           ts.add("grape");
            Iterator it=ts.iterator();
           while(it.hasNext())
           {
               String fruit=(String)it.next();
               System.out.println(fruit);
           }
        }
    }
    

    三、Map集合接口
    Map没有继承Collection接口,Map提供key到value的映射。一个Map中不能包含相同的key,每个key只能映射一个value。Map接口提供3种集合的视图,Map的内容可以被当作一组key集合,一组value集合,或者一组key-value映射。
    主要方法:
    boolean equals(Object o)比较对象
    boolean remove(Object o)删除一个对象
    put(Object key,Object value)添加key和value

    Hashtable类
    Hashtable继承Map接口,实现一个key-value映射的哈希表。任何非空(non-null)的对象都可作为key或者value。添加数据使用put(key,value),取出数据使用get(key),这两个基本操作的时间开销为常数。Hashtable通过initialcapacity和load factor两个参数调整性能。通常缺省的load factor0.75较好地实现了时间和空间的均衡。增大loadfactor可以节省空间但相应的查找时间将增大,这会影响像get和put这样的操作。
      由于作为key的对象将通过计算其散列函数来确定与之对应的value的位置,因此任何作为key的对象都必须实现hashCode和equals方法。hashCode和equals方法继承自根类Object,如果你用自定义的类当作key的话,要相当小心,按照散列函数的定义,如果两个对象相同,即obj1.equals(obj2)=true,则它们的hashCode必须相同,但如果两个对象不同,则它们的hashCode不一定不同,如果两个不同对象的hashCode相同,这种现象称为冲突,冲突会导致操作哈希表的时间开销增大,所以尽量定义好的hashCode()方法,能加快哈希表的操作。
      如果相同的对象有不同的hashCode,对哈希表的操作会出现意想不到的结果(期待的get方法返回null),要避免这种问题,只需要牢记一条:要同时复写equals方法和hashCode方法,而不要只写其中一个。

    HashMap类
    HashMap和Hashtable类似,不同之处在于HashMap是非同步的,并且允许null,即null value和null key,但是将HashMap视为Collection时(values()方法可返回Collection),其迭代子操作时间开销和HashMap的容量成比例。因此,如果迭代操作的性能相当重要的话,不要将HashMap的初始化容量设得过高,或者loadfactor过低。

    JDK1.0引入了第一个关联的集合类HashTable,它是线程安全的。 HashTable的所有方法都是同步的。
    JDK2.0引入了HashMap,它提供了一个不同步的基类和一个同步的包装器synchronizedMap。synchronizedMap被称为有条件的线程安全类。
    JDK5.0util.concurrent包中引入对Map线程安全的实现ConcurrentHashMap,比起synchronizedMap,它提供了更高的灵活性。同时进行的读和写操作都可以并发地。
    HashTable和HashMap区别
    第一、继承不同。
      public class Hashtable extends Dictionary implements Map
      public class HashMap extends AbstractMap implements Map
    第二、Hashtable 中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。在多线程并发的环境下,可以直接使用Hashtable,但是要使用HashMap的话就要自己增加同步处理了。
    第三、Hashtable中,key和value都不允许出现null值。在HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示 HashMap中没有该键,也可以表示该键所对应的值为null。因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键, 而应该用containsKey()方法来判断。
    第四、两个遍历方式的内部实现上不同。Hashtable、HashMap都使用了 Iterator。而由于历史原因,Hashtable还使用了Enumeration的方式 。
    第五、哈希值的使用不同,HashTable直接使用对象的hashCode。而HashMap重新计算hash值。
    第六、Hashtable和HashMap它们两个内部实现方式的数组的初始大小和扩容的方式。HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
    WeakHashMap类
    WeakHashMap是一种改进的HashMap,它对key实行“弱引用”,如果一个key不再被外部所引用,那么该key可以被GC回收。

    原文:https://blog.csdn.net/u013030086/article/details/84791668

    展开全文
  • java 容器都有哪些

    万次阅读 多人点赞 2019-07-27 18:36:57
    容器可以说是Java Core中比较重要的一部分了。 数组,String,java.util下的集合容器 ============================================================================== 数组长度限制为 Integer.Integer.MAX_...

    容器可以说是Java Core中比较重要的一部分了。

    数组,String,java.util下的集合容器

    ==============================================================================

    数组长度限制为 Integer.Integer.MAX_VALUE;

    String的长度限制: 底层是char 数组 长度 Integer.MAX_VALUE 线程安全的

    java.util下的集合容器

    这一块之所以重要是因为,各个接口的特性不同。下面说一下我对这些类的理解。

    Set下各种实现类对比

    HashSet基于哈希表实现,有以下特点:

              1.不允许重复

               2.允许值为null,但是只能有一个

               3.无序的。

               4.没有索引,所以不包含索引操作的方法

    LinkedHashSet跟HashSet一样都是基于哈希表实现。只不过linkedHashSet在hashSet的基础上多了一个链表,这个链表就是用来维护容器中每个元素的顺序的。有以下特点:

               1.不允许重复

               2.允许值为null,但是只能有一个

               3.有序的。

               4.没有索引,所以不包含索引操作的方法

    TreeSet是SortedSet接口的唯一实现类,是基于二叉树实现的。TreeSet可以确保集合元素处于排序状态。TreeSet支持两种排序方式,自然排序 和定制排序,其中自然排序为默认的排序方式。向TreeSet中加入的应该是同一个类的对象。有以下特点:

               1.不允许重复

               2.不允许null值

               3.没有索引,所以不包含索引操作的方法

    List下各种实现类对比。(这几个类都是有序的,允许重复的)

    ArrayList是基于数组实现的,其特点是查询快,增删慢。

            查询快是因为数组的空间是连续的,查询时只要通过首地址和下标很快就能找到元素。

            增删慢是因为数组是不能扩容的,一旦增加或者删除元素,内部操作就是新开辟一个数组把元素copy到新的数组,老的数   组等待被垃圾回收。

    以元素增加为例,我们看一下内部实现的源码:

    LinkedList是基于链表实现的。相比于ArrayList其特点是查询慢,增删快。

    查询慢:因为链表在内存中开辟的空间不一定是连续的(基本上不可能是连续的)所以链表实现的方式是每个元素节点都会存放自己的地址,数据以及下一个节点的地址,这样把所有的元素连接起来。所以当要查询元素时只能一个一个的往下找,相比于数组的首地址加下标会慢上不少。

    下面是链表的数据存储方式:假设有三个元素

    Vector也是基于数组实现的,相比于arrayList它是线程安全的。如果不考虑线程安全它,ArrayList性能更优。

    Map是双列集合的超类。也就是键值对形式。

    HashMap和Hashtable都实现了Map接口,但决定用哪一个之前先要弄清楚它们之间的分别。主要的区别有:线程安全性,同步(synchronization),以及速度。

    • HashMap几乎可以等价于Hashtable,除了HashMap是非synchronized的,并可以接受null(HashMap可以接受为null的键值(key)和值(value),而Hashtable则不行)。
    • HashMap是非synchronized,而Hashtable是synchronized,这意味着Hashtable是线程安全的,多个线程可以共享一个Hashtable;而如果没有正确的同步的话,多个线程是不能共享HashMap的。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。
    • 另一个区别是HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的enumerator迭代器不是fail-fast的。所以当有其它线程改变了HashMap的结构(增加或者移除元素),将会抛出ConcurrentModificationException,但迭代器本身的remove()方法移除元素则不会抛出ConcurrentModificationException异常。但这并不是一个一定发生的行为,要看JVM。这条同样也是Enumeration和Iterator的区别。
    • 由于Hashtable是线程安全的也是synchronized,所以在单线程环境下它比HashMap要慢。如果你不需要同步,只需要单一线程,那么使用HashMap性能要好过Hashtable。
    • HashMap不能保证随着时间的推移Map中的元素次序是不变的。

    LinkedHashMap和hashMap的区别在于多维护了一个链表,用来存储每一个元素的顺序,就跟HashSet和LinkedHashSet差不多。

    HashMap通常比TreeMap快一点(树和哈希表的数据结构使然),建议多使用HashMap,在需要排序的Map时候才用TreeMap。

    欢迎加微信一起学习交流

    相关面试题可以查看      面试题系列

    展开全文
  • C#WinForm父级窗体内Panel容器中嵌入子窗体、程序主窗体设计例子 在项目开发中经常遇到父级窗体嵌入子窗体所以写了一个例子程序,顺便大概划分了下界面模块和配色,不足之处还望指点 具体展现效果链接地址:...
  • 第二部分归纳和比较了三类基于Docker的主流容器云项目,包括专注Docker容器编排与部署的容器云、专注应用支撑的容器云以及一切皆容器的Kubernetes,进而详细解读了Kubernetes核心源码的设计与实现,最后介绍了几种...
  • STL中容器的介绍及分类

    千次阅读 2020-09-14 09:52:26
    STL中容器的介绍及分类   C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现,称为容器,如 queues(队列)、lists(链表)、和 stacks(栈)等。 一、...

    STL中容器的介绍及分类

      C++ STL (Standard Template Library标准模板库) 是通用类模板和算法的集合,它提供给程序员一些标准的数据结构的实现,称为容器,如 queues(队列)、lists(链表)、和 stacks(栈)等。

    一、容器介绍

      STL容器是由一些运用最广的一些数据结构实现出来的。常用的数据结构有array(数组)、vector(向量)、list(列表)、tree(树)、stack(栈)、queue(队列)、hash table(散列表)、set(集合)、map(映射表)等等。这些数据结构按结构可以分为序列式(sequence)和关联式(associative)两种。
    容器分类
      上图是各种容器的衍生层关系(这里所谓的衍生,并非派生关系,而是内含关系),例如heap内涵一个vector、priority-queue内含一个heap、stack和queue都含一个deque、set/map/multiset/multimap都含有一个RB-tree、hash_都内含一个hashtbale。

    二、序列式容器

    概念:
      所谓序列式容器,其中的元素都是可序的,但是未必都是有序的。
    分类:
      顺序结构:vector、list、deque;
      容器适配器:stack、queue、priority-queue;
      之所以称为容器适配器,是因为例如stack、queue由只是将deque改头换面而已,所以它们是一种配接器(adapter);
      备注:C++语言本身提供一个序列式array(不属于STL范畴)。

    三、关联式容器

    概念:
      关联式容器,每笔数据(每个数据)都有一个键值(key)和一个实值(value)
    特点:
      当元素被插入到关联式容器中时,容器内部数据结构(RB-tree或hash-table等)依据其键值大小,以某种特定规则将这个元素放置于适当位置;
      关联式容器没有头尾(只有最大元素和最小元素),所以不会有push_back()、push_front()、pop_back()、pop_front()、begin()、end()等操作。
    分类:
      分为set(集合)、map(映射表)两大类,以及两大类的衍生体multiset(多键集合)、multimap(多键映射表)。
      SGI STL还提供了一个不在标准规格之列的关联式容器:hash table(散列表)以及以此hash table为底层机制而完成的hash_set(散列集合)、hash_map(散列映射表)、hash_multiset(散列多键集合)、hash_multimap(散列多键映射表)。
    底层实现:
      关联式容器的内部结构是一个balanced binary tree(平衡二叉树),以便获得良好的搜索效率。balanced binary tree有许多种类,包括AVL-tree、RB-tree、AA-tree,其中最被广泛应用于STL的是RB-tree(红黑树)。
      set、map、multiset、multimap底层均以RB-tree(红黑树)完成。RB-tree(红黑树)也是一个独立容器,但并不开放给外界使用。

    展开全文
  • 容器核心技术

    2021-01-07 11:08:10
    1.什么是容器容器是一种轻量级、可移植、自包含的软件打包技术,使应用程序可以在几乎任何地方以相同的方式运行。 2.为什么使用容器容器使软件具备了超强的可移植能力,docker为代码提供了一个基于容器的标准化...
  • fortran容器:此存储库包含一些Fortran的容器数据结构类型
  • 18.java 容器都有哪些

    千次阅读 2020-07-27 18:34:52
    JAVA容器类概述 1.常用容器分类 JAVA中的容器类主要分为两大类,一类是Map类,一类是Collections类,他们有一个共同的父接口Iterator,它提供基本的遍历,删除元素操作。Iterator还有一个子接口LinkIterator,它...
  • Web容器Web服务器及常见的Web容器哪些?  一、引言  首先来理解一下简单的一个请求发送到响应的过程。 首先,客户端,通常是浏览器或者一些应用发送请求到你的服务器地址,比如访问你的Url或者其他的东西。而...
  • 第二部分归纳和比较了三类基于Docker的主流容器云项目,包括专注Docker容器编排与部署的容器云、专注应用支撑的容器云以及一切皆容器的Kubernetes,进而详细解读了Kubernetes核心源码的设计与实现,最后介绍了几种...
  • Docker+容器容器

    2017-11-03 11:19:34
    第二部分深入解读基于Docker的主流容器云技术,讲解了构建自己的容器云的方法,深入分析了3类Docker容器云技术的实现方法的设计思路,包括专注Docker容器编排与部署的容器云(Compose、Machine、Swarm、Fleet)、...
  • 一、服务器和容器 1. Web服务器 2. Web容器 ① Web容器的组成 ② Web容器的作用 3. Servlet容器 ① Servlet容器的作用 ② Servlet容器的工作过程 ③ Servlet ④ Servlet的工作过程 ⑤ Servlet变化过程 4. Spring容器...
  • 怎样查看spring容器哪些bean

    万次阅读 2017-09-14 16:21:42
    测试类: public static void main(String args[]) { ApplicationContext context=new ClassPathXmlApplicationContext("classpath:spring-applicationContext.xml"); Object user= context.getBean(...
  • c++中容器之总结篇

    2020-12-31 18:37:14
    顺序容器中有包含有顺序容器适配器。 顺序容器:将单一类型元素聚集起来成为容器,然后根据位置来存储和访问这些元素。主要有vector、list、deque(双端队列)。顺序容器适配器:stack、queue和priority_queue。 ...
  • vector容器 vector容器是一个动态数组的结构,在内存中有一个指针指向一块连续的内存。类似数组结构一样。它的特点支持随机访问数据,因为其在内存中的单元是连续。如此之外,还可以vector的大小是可以自动增长的。...
  • 容器的基本概念: 1.Collection:一个独立元素的序列,这些元素都服从一条或者多条规则。 List必须按照插入的...java容器主要包含Collection和Map两大类,其下又有很多子类,如下图所示: 3.Collection 和 Collec...
  • 精通容器容器

    2018-05-08 07:13:31
    第二部分深入解读基于Docker的主流容器云技术,讲解了构建自己的容器云的方法,深入分析了3类Docker容器云技术的实现方法的设计思路,包括专注Docker容器编排与部署的容器云(Compose、Machine、Swarm、Fleet)、...
  • 第二部分深入解读基于Docker的主流容器云技术,讲解了构建自己的容器云的方法,深入分析了3类Docker容器云技术的实现方法的设计思路,包括专注Docker容器编排与部署的容器云(Compose、Machine、Swarm、Fleet)、...
  • WEB应用容器详细介绍

    2021-09-30 12:05:12
    web容器(web服务器)主要有:Apache、IIS、Tomcat、Jetty、JBoss、webLogic等,而Tomcat、Jetty、JBoss、webLogic同时也是servlet容器,或者说他们还包含了servlet容器。没有servlet容器,你也可以用web容器直接...
  • 学习笔记:C#常用容器(集合)

    万次阅读 多人点赞 2019-04-09 09:36:50
    LinkedListNode被LinkedList类包含,用LinkedListNode类,可以获得元素的上一个与下一个元素的引用。 LinkedList < int > list = new LinkedList < int > ( ) ; list . AddFirst ( 2 ) ; list . AddFirst ( 1...
  • docker容器容器

    2018-09-20 17:22:38
    docker容器基础知识;框架;使用; 包含集群化知识,包含kubernetes知识;是docker入门书籍。
  • 常见的Web容器

    千次阅读 2020-04-22 13:59:41
    但JBoss核心服务不包括支持servlet/JSP的WEB容器,一般与Tomcat或Jetty绑定使用。 特点:JBoss是免费的、JBoss需要的内存和硬盘空间比较小、安装非常简单、、JBoss能够"热部署"、JBoss与Web服务器在同一个Java虚拟机...
  • 容器状态 在使用了几天docker之后,大概会用了,虽然坑走过了,再复现也不难,但是终归不想再重复一边。 之前听同事说,这个容器是可以被关闭的,额。。。担心容器里操作的数据没了,所以要了解一些容器的状态 首先...
  • Spring 容器简介

    千次阅读 2020-01-09 14:04:21
    Spring容器,我们常用的就是ApplicationContext,容器本身是存放Bean和Bean之间的依赖关系的,那么容器的生命周期是什么概念呢? 我们可以尝试从Bean的生命周期来推敲,Spring容器本身也是一个对象,既然是对象,那...
  • Kubernetes基础:包含多个容器的Pod

    千次阅读 2020-02-09 18:40:51
    在前面的文章中介绍了Pod的使用方法,示例中的Pod包含一个容器,这篇文章介绍一下包含多个容器的Pod的使用方法。
  • J2EE中的容器指什么?包括哪些

    千次阅读 2013-07-31 14:19:46
    主要的容器包括: WEB容器:给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,使JSP,SERVLET直接更容器中的环境变量接口交互,不必关注其它系统问题。主要有WEB服务器来实现。例如:TOMCAT,WEBLOGIC,...
  • 精选的10个容器包含十个精选的容器对应的应用案例。
  • 容器一直是应用程序开发行业的显着趋势之一,因为越来越多的组织选择它们来更快地构建、测试和部署他们的应用程序而没有摩擦。 容器本质上不是安全的。尽管容器具有内置的安全功能,但它们仍然需要第三方工具来保护...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 960,470
精华内容 384,188
关键字:

容器包括哪些