JAVA语言.util.Map接口翻译及详解
小标 2018-12-26 来源 : 阅读 886 评论 0

摘要:本文主要向大家介绍了JAVA语言.util.Map接口翻译及详解,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

本文主要向大家介绍了JAVA语言.util.Map接口翻译及详解,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

public interface Map{

 

    /**

     * Returns the number of key-value mappings in this map.  If the

     * map contains more than Integer.MAX_VALUE elements, returns

     * Integer.MAX_VALUE.


     *

     * 返回map中key-value映射的数量。

     * 如果map中包含的元素(key-value映射)数量超过Integer的最大值,返回Integer的最大值。


     *

     * @return the number of key-value mappings in this map

     */

    int size();

 

    /**

     * Returns true if this map contains no key-value mappings.


     *

     * 如果map中没有key-value键值对,返回true。


     *

     * @return true if this map contains no key-value mappings

     */

    boolean isEmpty();

 

    /**

     * Returns true if this map contains a mapping for the specified

     * key.  More formally, returns true if and only if

     * this map contains a mapping for a key k such that

     * (key==null ? k==null : key.equals(k)).  (There can be

     * at most one such mapping.)


     *

     * 如果该map包含指定key的映射,那么返回true,否则返回false。


     *

     * @param key key whose presence in this map is to be tested

     *

     * @return true if this map contains a mapping for the specified

     *         key

     * @throws ClassCastException if the key is of an inappropriate type for

     *         this map

     * (optional)


     *

     * 如果key的类型不符合,抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified key is null and this map

     *         does not permit null keys

     * (optional)


     *

     * 如果该map不支持key为null,传入null将抛出NullPointerException


     */

    boolean containsKey(Object key);

 

    /**

     * Returns true if this map maps one or more keys to the

     * specified value.  More formally, returns true if and only if

     * this map contains at least one mapping to a value v such that

     * (value==null ? v==null : value.equals(v)).  This operation

     * will probably require time linear in the map size for most

     * implementations of the Map interface.


     *

     * 如果该map含有一个或以上的key映射到指定的value,那么返回true,否则返回false

     * 对于大多数Map接口的实现,这个操作可能需要根据map的大小花费相应的线性时间


     *

     * @param value value whose presence in this map is to be tested

     * @return true if this map maps one or more keys to the

     *         specified value

     * @throws ClassCastException if the value is of an inappropriate type for

     *         this map

     * (optional)


     *

     * 如果key的类型不符合,抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified value is null and this

     *         map does not permit null values

     * (optional)


     *

     * 如果map不支持value为null,传入null将抛出NullPointerException


     */

    boolean containsValue(Object value);

 

    /**

     * Returns the value to which the specified key is mapped,

     * or {@code null} if this map contains no mapping for the key.


     *

     * 返回指定key映射的value,如果没有映射返回null


     *

     *

More formally, if this map contains a mapping from a key

     * {@code k} to a value {@code v} such that {@code (key==null ? k==null :

     * key.equals(k))}, then this method returns {@code v}; otherwise

     * it returns {@code null}.  (There can be at most one such mapping.)

     *

     *

If this map permits null values, then a return value of

     * {@code null} does not necessarily indicate that the map

     * contains no mapping for the key; it's also possible that the map

     * explicitly maps the key to {@code null}.  The {@link #containsKey

     * containsKey} operation may be used to distinguish these two cases.


     *

     * 如果该map允许value为null,返回值value为null不一定表明指定key在该map中没有映射;也可能是key对应的value就是null。

     * containsKey操作可用于区分这两种情况


     *

     * @param key the key whose associated value is to be returned

     * @return the value to which the specified key is mapped, or

     *         {@code null} if this map contains no mapping for the key

     * @throws ClassCastException if the key is of an inappropriate type for

     *         this map

     * (optional)


     *

     * 如果key的类型不符合,抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified key is null and this map

     *         does not permit null keys

     * (optional)


     *

     * 如果该map不支持key为null,传入null将抛出NullPointerException


     */

    V get(Object key);

 

    // Modification Operations

 

    /**

     * Associates the specified value with the specified key in this map

     * (optional operation).  If the map previously contained a mapping for

     * the key, the old value is replaced by the specified value.  (A map

     * m is said to contain a mapping for a key k if and only

     * if {@link #containsKey(Object) m.containsKey(k)} would return

     * true.)


     *

     * 将key和value以键值对的方式放入map中。

     * 如果map中已经包含了以key映射的键值对,那么新的value将会取代旧的value。

     * 一个map已经包含以key映射的键值对的依据是m.containsKey(k)的方法返回true。


     *

     * @param key key with which the specified value is to be associated

     * @param value value to be associated with the specified key

     * @return the previous value associated with key, or

     *         null if there was no mapping for key.

     *         (A null return can also indicate that the map

     *         previously associated null with key,

     *         if the implementation supports null values.)


     *        

     * 返回值是key先前对应的value,如果没有key对应的映射,那么返回null

     * 如果Map的实现类支持value的值为null,那么返回null也可以表明key在先前对应的value就是null


     *        

     * @throws UnsupportedOperationException if the put operation

     *         is not supported by this map


     * 如果该map不支持put操作将抛出异常UnsupportedOperationException


     *

     * @throws ClassCastException if the class of the specified key or value

     *         prevents it from being stored in this map


     * 如果map阻止保存指定key或value的类型,抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified key or value is null

     *         and this map does not permit null keys or values


     * 如果该map不支持key或value为null,传入null将抛出NullPointerException


     *

     * @throws IllegalArgumentException if some property of the specified key

     *         or value prevents it from being stored in this map


     * 如果该map阻止保存指定key或value的某些属性,抛出IllegalArgumentException异常


     */

    V put(K key, V value);

 

    /**

     * Removes the mapping for a key from this map if it is present

     * (optional operation).   More formally, if this map contains a mapping

     * from key k to value v such that

     * (key==null ?  k==null : key.equals(k)), that mapping

     * is removed.  (The map can contain at most one such mapping.)


     *

     * 如果该map包含key的映射,那么删除该映射。


     *

     *

Returns the value to which this map previously associated the key,

     * or null if the map contained no mapping for the key.


     *

     * 返回值是key先前对应的value,如果没有key对应的映射,那么返回null。


     *

     *

If this map permits null values, then a return value of

     * null does not necessarily indicate that the map

     * contained no mapping for the key; it's also possible that the map

     * explicitly mapped the key to null.


     *

     * 如果map支持value的值为null,那么返回null也可能表明key在先前对应的value就是null。


     *

     *

The map will not contain a mapping for the specified key once the

     * call returns.


     *

     * 一旦调用返回,该map将不再包含指定key的映射。


     *

     * @param key key whose mapping is to be removed from the map

     * @return the previous value associated with key, or

     *         null if there was no mapping for key.


     * 返回值是key先前对应的value,如果没有key对应的映射,那么返回null


     *

     * @throws UnsupportedOperationException if the remove operation

     *         is not supported by this map


     * 如果该map不支持remove操作将抛出异常UnsupportedOperationException


     *

     * @throws ClassCastException if the key is of an inappropriate type for

     *         this map

     * (optional)


     * 如果key是非法类型,那么抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified key is null and this

     *         map does not permit null keys

     * (optional)


     * 如果该map不支持key为null,传入null将抛出NullPointerException


     */

    V remove(Object key);

 

    // Bulk Operations

 

    /**

     * Copies all of the mappings from the specified map to this map

     * (optional operation).  The effect of this call is equivalent to that

     * of calling {@link #put(Object,Object) put(k, v)} on this map once

     * for each mapping from key k to value v in the

     * specified map.  The behavior of this operation is undefined if the

     * specified map is modified while the operation is in progress.


     *

     * 从指定的map中拷贝所有的映射到该map中。

     * 这个调用的作用相当于把指定map中的每一个key-value键值对都调用put(key,value)方法放入该map中。

     * 如果在此操作过程中指定map被修改了,那么这个操作的行为是未定义的。


     *

     * @param m mappings to be stored in this map

     * @throws UnsupportedOperationException if the putAll operation

     *         is not supported by this map


     * 如果该map不支持putAll操作将抛出异常UnsupportedOperationException


     *

     * @throws ClassCastException if the class of a key or value in the

     *         specified map prevents it from being stored in this map


     * 如果key或value是非法类型,那么抛出ClassCastException异常


     *

     * @throws NullPointerException if the specified map is null, or if

     *         this map does not permit null keys or values, and the

     *         specified map contains null keys or values


     * 如果指定map为null,或该map不支持key或value为null且指定map中key或value存在null,将抛出NullPointerException


     *

     * @throws IllegalArgumentException if some property of a key or value in

     *         the specified map prevents it from being stored in this map


     * 如果该map阻止保存指定key或value的某些属性,抛出IllegalArgumentException异常


     */

    void putAll(Map m);

 

    /**

     * Removes all of the mappings from this map (optional operation).

     * The map will be empty after this call returns.


     *

     * 删除该map中的所有映射。

     * 在调用后该map为空。


     *

     * @throws UnsupportedOperationException if the clear operation

     *         is not supported by this map


     * 如果该map不支持clear操作将抛出异常UnsupportedOperationException


     */

    void clear();

 

    // Views

 

    /**

     * Returns a {@link Set} view of the keys contained in this map.

     * The set is backed by the map, so changes to the map are

     * reflected in the set, and vice-versa.  If the map is modified

     * while an iteration over the set is in progress (except through

     * the iterator's own remove operation), the results of

     * the iteration are undefined.  The set supports element removal,

     * which removes the corresponding mapping from the map, via the

     * Iterator.remove, Set.remove,

     * removeAll, retainAll, and clear

     * operations.  It does not support the add or addAll

     * operations.


     *

     * 返回该map中所有key的Set视图。

     * 该set是由map支持的,所以对map的更改将影响到set,反之亦然。

     * 如果在迭代set的过程中map被修改了(除了迭代器使用自己的remove操作),那么迭代的结果是未定义的。

     * 该set支持删除map中映射的操作,其中方法包括Iterator.remove、Set.remove、removeAll、retainAll及clear。

     * 但是不支持add或addAll操作。


     *

     * @return a set view of the keys contained in this map

     */

    SetkeySet();

 

    /**

     * Returns a {@link Collection} view of the values contained in this map.

     * The collection is backed by the map, so changes to the map are

     * reflected in the collection, and vice-versa.  If the map is

     * modified while an iteration over the collection is in progress

     * (except through the iterator's own remove operation),

     * the results of the iteration are undefined.  The collection

     * supports element removal, which removes the corresponding

     * mapping from the map, via the Iterator.remove,

     * Collection.remove, removeAll,

     * retainAll and clear operations.  It does not

     * support the add or addAll operations.


     *

     * 返回该map中所有value的Collection视图。

     * 该collection是由map支持的,所以对map的更改将影响到collection,反之亦然。

     * 如果在迭代collection的过程中map被修改了(除了迭代器使用自己的remove操作),那么迭代的结果是未定义的。

     * 该collection支持删除map中映射的操作,其中方法包括Iterator.remove、Collection.remove、removeAll、retainAll及clear。

     * 但是不支持add或addAll操作。


     *

     * @return a collection view of the values contained in this map

     */

    Collectionvalues();

 

    /**

     * Returns a {@link Set} view of the mappings contained in this map.

     * The set is backed by the map, so changes to the map are

     * reflected in the set, and vice-versa.  If the map is modified

     * while an iteration over the set is in progress (except through

     * the iterator's own remove operation, or through the

     * setValue operation on a map entry returned by the

     * iterator) the results of the iteration are undefined.  The set

     * supports element removal, which removes the corresponding

     * mapping from the map, via the Iterator.remove,

     * Set.remove, removeAll, retainAll and

     * clear operations.  It does not support the

     * add or addAll operations.


     *

     * 返回该map中所有映射的Set视图。

     * 该set是由map支持的,所以对map的更改将影响到set,反之亦然。

     * 如果在迭代set的过程中map被修改了(除了迭代器使用自己的remove操作,或者setValue操作),那么迭代的结果是未定义的。

     * 该set支持删除map中映射的操作,其中方法包括Iterator.remove、Set.remove、removeAll、retainAll及clear。

     * 但是不支持add或addAll操作。


     *

     * @return a set view of the mappings contained in this map

     */

    Set<map.entry> entrySet();

 

    /**

     * A map entry (key-value pair).  The Map.entrySet method returns

     * a collection-view of the map, whose elements are of this class.  The

     * only way to obtain a reference to a map entry is from the

     * iterator of this collection-view.  These Map.Entry objects are

     * valid only for the duration of the iteration; more formally,

     * the behavior of a map entry is undefined if the backing map has been

     * modified after the entry was returned by the iterator, except through

     * the setValue operation on the map entry.


     *

     * 一条map的记录(一个键值对)。

     * Map.entrySet方法返回的collection视图中的元素就是这个类(Entry)。

     * 唯一一个获得entry引用的方式,是从collection视图的迭代器中获取。

     * 这些Map.Entry对象只在迭代期间有效;

     * 更正式的,如果在entry的迭代器返回后,作为支持的map被修改了(除了entry的setValue操作),那么entry的行为是未定义的。


     *

     * @see Map#entrySet()

     * @since 1.2

     */

    interface Entry{

        /**

         * Returns the key corresponding to this entry.


         *

         * 返回该entry对应的key。


         *

         * @return the key corresponding to this entry

         * @throws IllegalStateException implementations may, but are not

         *         required to, throw this exception if the entry has been

         *         removed from the backing map.


         * 一种实现方式,但是不做要求,如果entry已经被支持的map中删除了,抛出IllegalStateException异常


         */

        K getKey();

 

        /**

         * Returns the value corresponding to this entry.  If the mapping

         * has been removed from the backing map (by the iterator's

         * remove operation), the results of this call are undefined.


         *

         * 返回该entry对应的value。

         * 如果在作为支持的map中删除了该映射(用迭代器的remove操作),那么调用的结果是未定义的。


         *

         * @return the value corresponding to this entry

         * @throws IllegalStateException implementations may, but are not

         *         required to, throw this exception if the entry has been

         *         removed from the backing map.


         * 一种实现方式,但是不做要求,如果entry已经被支持的map中删除了,抛出IllegalStateException异常


         */

        V getValue();

 

        /**

         * Replaces the value corresponding to this entry with the specified

         * value (optional operation).  (Writes through to the map.)  The

         * behavior of this call is undefined if the mapping has already been

         * removed from the map (by the iterator's remove operation).


         *

         * 用指定value替换该entry中对应的value(可选的操作)。

         * 该操作会影响到map上。

         * 如果在map上的映射已经被删除了(使用迭代器的remove方法),那么这个行为的调用是未定义的。


         *

         * @param value new value to be stored in this entry

         * @return old value corresponding to the entry


         * 返回值是先前entry对应的value值


         *

         * @throws UnsupportedOperationException if the put operation

         *         is not supported by the backing map


         * 如果作为支持的map不支持put操作将抛出异常UnsupportedOperationException


         *

         * @throws ClassCastException if the class of the specified value

         *         prevents it from being stored in the backing map


         * 如果指定value的类是被作为支持的map阻止的,那么抛出ClassCastException异常


         *

         * @throws NullPointerException if the backing map does not permit

         *         null values, and the specified value is null


         * 如果作为支持map不支持value为null,传入null将抛出NullPointerException


         *

         * @throws IllegalArgumentException if some property of this value

         *         prevents it from being stored in the backing map


         * 如果作为支持的map阻止保存指定value的某些属性,抛出IllegalArgumentException异常


         *

         * @throws IllegalStateException implementations may, but are not

         *         required to, throw this exception if the entry has been

         *         removed from the backing map.


         * 一种实现方式,但是不做要求,如果entry已经被支持的map中删除了,抛出IllegalStateException异常


         */

        V setValue(V value);

 

        /**

         * Compares the specified object with this entry for equality.

         * Returns true if the given object is also a map entry and

         * the two entries represent the same mapping.  More formally, two

         * entries e1 and e2 represent the same mapping

         * if

       *     (e1.getKey()==null ?

         *      e2.getKey()==null : e1.getKey().equals(e2.getKey()))  &&

         *     (e1.getValue()==null ?

         *      e2.getValue()==null : e1.getValue().equals(e2.getValue()))

         *

* This ensures that the equals method works properly across * different implementations of the Map.Entry interface.


* * 平等地比较指定object和该entry是否相等。 * 如果指定的object也是一个entry,并且这两个entry表示同一个映射,那么返回true。 * 更正式的,按照如下方式判断两个entry是否相等: * (e1.getKey()==null ? e2.getKey()==null : e1.getKey().equals(e2.getKey())) * && * (e1.getValue()==null ? e2.getValue()==null : e1.getValue().equals(e2.getValue())) * 这样确保了equals方法可以在不同的Map.Entry实现类中正常工作。


* * @param o object to be compared for equality with this map entry * @return true if the specified object is equal to this map * entry


* 如果指定object和该entry相等,返回true


*/ boolean equals(Object o); /** * Returns the hash code value for this map entry. The hash code * of a map entry e is defined to be:


         *     (e.getKey()==null   ? 0 : e.getKey().hashCode()) ^

         *     (e.getValue()==null ? 0 : e.getValue().hashCode())

         *

* This ensures that e1.equals(e2) implies that * e1.hashCode()==e2.hashCode() for any two Entries * e1 and e2, as required by the general * contract of Object.hashCode.


* * 返回该entry的哈希码。 * 一个entry的哈希码是按照如下定义的: * (e.getKey()==null ? 0 : e.getKey().hashCode()) ^ (e.getValue()==null ? 0 : e.getValue().hashCode()) * 这样确保了对于任意两个entry如e1和e2,如果e1.equals(e2),那么意味着e1.hashCode()==e2.hashCode(), * 按照一般的要求规定Object.hasCode。


* * @return the hash code value for this map entry * @see Object#hashCode() * @see Object#equals(Object) * @see #equals(Object) */ int hashCode(); /** * Returns a comparator that compares {@link Map.Entry} in natural order on key.


* * 返回一个Map.Entry的比较器,按照key的自然排序进行比较。


* *


The returned comparator is serializable and throws {@link * NullPointerException} when comparing an entry with a null key.


* * 返回的比较器是可序列化的,当entry与空值进行比较时抛出NullPointerException。


* * @paramthe {@link Comparable} type of then map keys


* key的泛型要求实现Comparable接口,因为返回的Comparator接口的compare方法要使用key泛型的compareTo接口进行比较


* * @paramthe type of the map values * @return a comparator that compares {@link Map.Entry} in natural order on key. * @see Comparable * @since 1.8 */ public static, V> Comparator<map.entry> comparingByKey() { // 返回比较器对Map.Entry进行比较,比较的方式采用key的自然排序 // &表示返回比较器既要实现Comparator接口,也要实现Serializable接口 // 采用Lambda表达式形式返回函数式接口Comparator return (Comparator<map.entry> & Serializable) (c1, c2) -> c1.getKey().compareTo(c2.getKey()); } /** * Returns a comparator that compares {@link Map.Entry} in natural order on value.


* * 返回一个Map.Entry的比较器,按照value的自然排序进行比较。


* *


The returned comparator is serializable and throws {@link * NullPointerException} when comparing an entry with null values.


* * 返回的比较器是可序列化的,当entry与空值进行比较时抛出NullPointerException


* * @paramthe type of the map keys * @paramthe {@link Comparable} type of the map values


* value的泛型要求实现Comparable接口,因为返回的Comparator接口的compare方法要使用value泛型的compareTo接口进行比较


* * @return a comparator that compares {@link Map.Entry} in natural order on value. * @see Comparable * @since 1.8 */ public static> Comparator<map.entry> comparingByValue() { return (Comparator<map.entry> & Serializable) (c1, c2) -> c1.getValue().compareTo(c2.getValue()); } /** * Returns a comparator that compares {@link Map.Entry} by key using the given * {@link Comparator}.


* * 返回一个Map.Entry的比较器,使用给定key的比较器进行比较。


* *


The returned comparator is serializable if the specified comparator * is also serializable.


* * 如果指定的比较器是可序列化的,那么返回的比较器也要求是可序列化的。


* * @paramthe type of the map keys * @paramthe type of the map values * @param cmp the key {@link Comparator}


* 入参cmp是一个比较器


* * @return a comparator that compares {@link Map.Entry} by the key. * @since 1.8 */ public staticComparator<map.entry> comparingByKey(Comparatorcmp) { // 判断cmp是否为空,如果为空抛出NullPointerException Objects.requireNonNull(cmp); return (Comparator<map.entry> & Serializable) (c1, c2) -> cmp.compare(c1.getKey(), c2.getKey()); } /** * Returns a comparator that compares {@link Map.Entry} by value using the given * {@link Comparator}.


* * 返回一个Map.Entry的比较器,使用给定value的比较器进行比较。


* *


The returned comparator is serializable if the specified comparator * is also serializable.


* * 如果指定的比较器是可序列化的,那么返回的比较器也要求是可序列化的。


* * @paramthe type of the map keys * @paramthe type of the map values * @param cmp the value {@link Comparator} * @return a comparator that compares {@link Map.Entry} by the value. * @since 1.8 */ public staticComparator<map.entry> comparingByValue(Comparatorcmp) { Objects.requireNonNull(cmp); return (Comparator<map.entry> & Serializable) (c1, c2) -> cmp.compare(c1.getValue(), c2.getValue()); } } // Comparison and hashing // 比较和散列 /** * Compares the specified object with this map for equality. Returns * true if the given object is also a map and the two maps * represent the same mappings. More formally, two maps m1 and * m2 represent the same mappings if * m1.entrySet().equals(m2.entrySet()). This ensures that the * equals method works properly across different implementations * of the Map interface.


* * 平等地比较指定object和该map是否相等。 * 如果指定的object也是一个map,并且这两个map表示同一个映射,那么返回true。 * 更正式的,对于两个map如m1和m2,如果m1.entrySet().equals(m2.entrySet()),那么他们代表相同的映射。 * 这样确保了equals方法可以在不同的Map实现类中正常工作。


* * @param o object to be compared for equality with this map * @return true if the specified object is equal to this map */ boolean equals(Object o); /** * Returns the hash code value for this map. The hash code of a map is * defined to be the sum of the hash codes of each entry in the map's * entrySet() view. This ensures that m1.equals(m2) * implies that m1.hashCode()==m2.hashCode() for any two maps * m1 and m2, as required by the general contract of * {@link Object#hashCode}. * * 返回该map的哈希码。 * 一个map的哈希码被定义为该map的entrySet视图中每个entry的哈希码的和。 * 这样确保了对于任意两个map如m1和m2,如果m1.equals(m2),那么意味着e1.hashCode()==e2.hashCode(), * 按照一般的要求规定Object.hasCode。 * * @return the hash code value for this map * @see Map.Entry#hashCode() * @see Object#equals(Object) * @see #equals(Object) */ int hashCode(); // Defaultable methods /** * Returns the value to which the specified key is mapped, or * {@code defaultValue} if this map contains no mapping for the key.


* * 返回指定的key对应的value,如果map不包含key的映射,那么返回传入的默认值。


* * @implSpec * The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param key the key whose associated value is to be returned * @param defaultValue the default mapping of the key * @return the value to which the specified key is mapped, or * {@code defaultValue} if this map contains no mapping for the key * @throws ClassCastException if the key is of an inappropriate type for * this map * (optional)


* * 如果key的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified key is null and this map * does not permit null keys * (optional)


* * 如果该map不支持key为null,传入null将抛出NullPointerException


* * @since 1.8 */ default V getOrDefault(Object key, V defaultValue) { V v; return (((v = get(key)) != null) || containsKey(key)) ? v : defaultValue; } /** * Performs the given action for each entry in this map until all entries * have been processed or the action throws an exception. Unless * otherwise specified by the implementing class, actions are performed in * the order of entry set iteration (if an iteration order is specified.) * Exceptions thrown by the action are relayed to the caller.


* * 在此map中对每个entry执行给定的操作,直到所有的entry执行完成或者抛出异常。 * 除非实现类另有规定,否则操作将按照entey set迭代器的顺序执行(如果迭代器指定了顺序)。 * 由操作引发的的异常会传递给调用者。


* * @implSpec * The default implementation is equivalent to, for this {@code map}: *

{@code

     * for (Map.Entryentry : map.entrySet())

     *     action.accept(entry.getKey(), entry.getValue());

     * }


* * 默认的实现等价于如下:


* for (Map.Entryentry : map.entrySet()) * action.accept(entry.getKey(), entry.getValue()); * }


* * The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. * * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param action The action to be performed for each entry * @throws NullPointerException if the specified action is null * @throws ConcurrentModificationException if an entry is found to be * removed during iteration * @since 1.8 */ default void forEach(BiConsumeraction) { Objects.requireNonNull(action); for (Map.Entryentry : entrySet()) { K k; V v; try { k = entry.getKey(); v = entry.getValue(); } catch (IllegalStateException ise) { // this usually means the entry is no longer in the map. throw new ConcurrentModificationException(ise); } action.accept(k, v); } } /** * Replaces each entry's value with the result of invoking the given * function on that entry until all entries have been processed or the * function throws an exception. Exceptions thrown by the function are * relayed to the caller.


* * 将每个entry的value替换为在该entry上调用给定函数的结果,直到所有的entry执行完成或者抛出异常。 * 由操作引发的的异常会传递给调用者。


* * @implSpec *


The default implementation is equivalent to, for this {@code map}: *

{@code

     * for (Map.Entryentry : map.entrySet())

     *     entry.setValue(function.apply(entry.getKey(), entry.getValue()));

     * }


* * 默认的实现等价于如下:


* for (Map.Entryentry : map.entrySet()) * entry.setValue(function.apply(entry.getKey(), entry.getValue())); * }


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param function the function to apply to each entry * @throws UnsupportedOperationException if the {@code set} operation * is not supported by this map's entry set iterator. * @throws ClassCastException if the class of a replacement value * prevents it from being stored in this map


* * 如果key的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified function is null, or the * specified replacement value is null, and this map does not permit null * values


* * 如果该map不支持key为null,传入null将抛出NullPointerException


* * @throws ClassCastException if a replacement value is of an inappropriate * type for this map * (optional) * @throws NullPointerException if function or a replacement value is null, * and this map does not permit null keys or values * (optional) * @throws IllegalArgumentException if some property of a replacement value * prevents it from being stored in this map * (optional) * @throws ConcurrentModificationException if an entry is found to be * removed during iteration * @since 1.8 */ default void replaceAll(BiFunctionfunction) { Objects.requireNonNull(function); for (Map.Entryentry : entrySet()) { K k; V v; try { k = entry.getKey(); v = entry.getValue(); } catch (IllegalStateException ise) { // this usually means the entry is no longer in the map. throw new ConcurrentModificationException(ise); } // ise thrown from function is not a cme. v = function.apply(k, v); try { entry.setValue(v); } catch (IllegalStateException ise) { // this usually means the entry is no longer in the map. throw new ConcurrentModificationException(ise); } } } /** * If the specified key is not already associated with a value (or is mapped * to {@code null}) associates it with the given value and returns * {@code null}, else returns the current value.


* * 如果指定的key没有与一个value关联(或者key的映射值是null),那么用给定value和key进行关联, * 并返回null,否则返回当前value。


* * @implSpec * The default implementation is equivalent to, for this {@code * map}: * *

{@code

     * V v = map.get(key);

     * if (v == null)

     *     v = map.put(key, value);

     *

     * return v;

     * }


* * 默认的实现等价于如下:


* V v = map.get(key); * if (v == null) * v = map.put(key, value); * return v;


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. * * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param key key with which the specified value is to be associated * @param value value to be associated with the specified key * @return the previous value associated with the specified key, or * {@code null} if there was no mapping for the key. * (A {@code null} return can also indicate that the map * previously associated {@code null} with the key, * if the implementation supports null values.) * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * (optional) * @throws ClassCastException if the key or value is of an inappropriate * type for this map


* (optional)


* * 如果key或者value的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified key or value is null, * and this map does not permit null keys or values * (optional) * * 如果该map不支持key或value为null,传入null将抛出NullPointerException


* * @throws IllegalArgumentException if some property of the specified key * or value prevents it from being stored in this map * (optional) * * 如果该map阻止保存指定key或value的某些属性,抛出IllegalArgumentException异常


* * @since 1.8 */ default V putIfAbsent(K key, V value) { V v = get(key); if (v == null) { v = put(key, value); } return v; } /** * Removes the entry for the specified key only if it is currently * mapped to the specified value.


* * 只有在当前key映射到指定的value时,才会移除指定key对应的entry。


* * @implSpec * The default implementation is equivalent to, for this {@code map}: * *

{@code

     * if (map.containsKey(key) && Objects.equals(map.get(key), value)) {

     *     map.remove(key);

     *     return true;

     * } else

     *     return false;

     * }

* * 默认的实现等价于如下:


* if (map.containsKey(key) && Objects.equals(map.get(key), value)) { * map.remove(key); * return true; * } else * return false; * }


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param key key with which the specified value is associated * @param value value expected to be associated with the specified key * @return {@code true} if the value was removed * @throws UnsupportedOperationException if the {@code remove} operation * is not supported by this map * (optional)


* * 如果该map不支持remove操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the key or value is of an inappropriate * type for this map * (optional)


* * 如果key或value的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified key or value is null, * and this map does not permit null keys or values * (optional)


* * 如果该map不支持key或value为null,传入null将抛出NullPointerException


* * @since 1.8 */ default boolean remove(Object key, Object value) { Object curValue = get(key); if (!Objects.equals(curValue, value) || (curValue == null && !containsKey(key))) { return false; } remove(key); return true; } /** * Replaces the entry for the specified key only if currently * mapped to the specified value.


* * 只有在当前key映射到指定的value时,才会替换指定key对应的entry。


* * @implSpec * The default implementation is equivalent to, for this {@code map}: * *

{@code

     * if (map.containsKey(key) && Objects.equals(map.get(key), value)) {

     *     map.put(key, newValue);

     *     return true;

     * } else

     *     return false;

     * }


* * 默认的实现等价于如下:


* if (map.containsKey(key) && Objects.equals(map.get(key), value)) { * map.put(key, newValue); * return true; * } else * return false; * }


* * The default implementation does not throw NullPointerException * for maps that do not support null values if oldValue is null unless * newValue is also null.


* * 如果oldValue为null,则默认实现不为不支持value为null的map抛出空异常,除非newValue也为null。


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param key key with which the specified value is associated * @param oldValue value expected to be associated with the specified key * @param newValue value to be associated with the specified key * @return {@code true} if the value was replaced * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of a specified key or value * prevents it from being stored in this map


* * 如果key或者value的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if a specified key or newValue is null, * and this map does not permit null keys or values


* * 如果该map不支持key为null,传入指定key为null或者newValue为null将抛出NullPointerException


* * @throws NullPointerException if oldValue is null and this map does not * permit null values * (optional)


* * 如果该map不支持value为null,并且oldValue为null,将抛出NullPointerException


* * @throws IllegalArgumentException if some property of a specified key * or value prevents it from being stored in this map


* 如果该map阻止保存指定key或value的某些属性,抛出IllegalArgumentException异常


* * @since 1.8 */ default boolean replace(K key, V oldValue, V newValue) { Object curValue = get(key); if (!Objects.equals(curValue, oldValue) || (curValue == null && !containsKey(key))) { return false; } put(key, newValue); return true; } /** * Replaces the entry for the specified key only if it is * currently mapped to some value.


* * 只有在当前key映射到某一个value时,才会替换指定key对应的entry。


* * @implSpec * The default implementation is equivalent to, for this {@code map}: * *

{@code

     * if (map.containsKey(key)) {

     *     return map.put(key, value);

     * } else

     *     return null;

     * }


* * 默认的实现等价于如下:


* if (map.containsKey(key)) { * return map.put(key, value); * } else * return null; * }


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。


* * @param key key with which the specified value is associated * @param value value to be associated with the specified key * @return the previous value associated with the specified key, or * {@code null} if there was no mapping for the key. * (A {@code null} return can also indicate that the map * previously associated {@code null} with the key, * if the implementation supports null values.) * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of the specified key or value * prevents it from being stored in this map * (optional)


* * 如果key的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified key or value is null, * and this map does not permit null keys or values


* * 如果该map不支持key或value为null,传入null将抛出NullPointerException


* * @throws IllegalArgumentException if some property of the specified key * or value prevents it from being stored in this map


* * 如果该map阻止保存指定key或value的某些属性,抛出IllegalArgumentException异常


* * @since 1.8 */ default V replace(K key, V value) { V curValue; if (((curValue = get(key)) != null) || containsKey(key)) { curValue = put(key, value); } return curValue; } /** * If the specified key is not already associated with a value (or is mapped * to {@code null}), attempts to compute its value using the given mapping * function and enters it into this map unless {@code null}.


* * 如果指定的key没有与一个value关联(或者key的映射值是null),那么尝试使用给定的映射函数计算value值, * 并将其写入到map中,除非计算出的value值为null。


* *


If the function returns {@code null} no mapping is recorded. If * the function itself throws an (unchecked) exception, the * exception is rethrown, and no mapping is recorded. The most * common usage is to construct a new object serving as an initial * mapped value or memoized result, as in: * *

{@code

     * map.computeIfAbsent(key, k -> new Value(f(k)));

     * }

* *


Or to implement a multi-value map, {@code Map<k,collection>}, * supporting multiple values per key: * *

{@code

     * map.computeIfAbsent(key, k -> new HashSet()).add(v);

     * }


* * 如果函数返回null,则不记录映射。如果函数本身抛出一个(为检查的)异常,则会重新抛出异常,不记录映射。 * 最常见的用法是构造一个新对象,作为初始映射值或memoized结果,如下:


* * map.computeIfAbsent(key, k -> new Value(f(k)));


* * 或者实现多value映射map,Map<k,collection>,支持一key多value:


* * map.computeIfAbsent(key, k -> new HashSet()).add(v);


* * @implSpec * The default implementation is equivalent to the following steps for this * {@code map}, then returning the current value or {@code null} if now * absent: * *

{@code

     * if (map.get(key) == null) {

     *     V newValue = mappingFunction.apply(key);

     *     if (newValue != null)

     *         map.put(key, newValue);

     * }

     * }


* * 默认的实现等价于如下所示,如果没有默认值,则返回当前value或null:


* if (map.get(key) == null) { * V newValue = mappingFunction.apply(key); * if (newValue != null) * map.put(key, newValue); * } * *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. In particular, all implementations of * subinterface {@link java.util.concurrent.ConcurrentMap} must document * whether the function is applied once atomically only if the value is not * present.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。 * 特别地,子接口java.util.concurrent.ConcurrentMap的所有实现都必须记录该函数是否仅在原子的情况下才被应用,除非value不存在。


* * @param key key with which the specified value is to be associated * @param mappingFunction the function to compute a value * @return the current (existing or computed) value associated with * the specified key, or null if the computed value is null * @throws NullPointerException if the specified key is null and * this map does not support null keys, or the mappingFunction * is null


* * 如果该map不支持keymappingFunction或为null,传入null将抛出NullPointerException


* * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of the specified key or value * prevents it from being stored in this map * (optional) * * 如果key或value的类型不符合,抛出ClassCastException异常


* * @since 1.8 */ default V computeIfAbsent(K key, FunctionmappingFunction) { Objects.requireNonNull(mappingFunction); V v; if ((v = get(key)) == null) { V newValue; if ((newValue = mappingFunction.apply(key)) != null) { put(key, newValue); return newValue; } } return v; } /** * If the value for the specified key is present and non-null, attempts to * compute a new mapping given the key and its current mapped value.


* * 如果指定key对应的value是存在的且不为null,尝试用给定key和当前映射的value计算出一个新的映射关系。


* *


If the function returns {@code null}, the mapping is removed. If the * function itself throws an (unchecked) exception, the exception is * rethrown, and the current mapping is left unchanged.


* * 如果函数返回null,则移除映射。如果函数本身抛出一个(为检查的)异常,则会重新抛出异常,当前映射保持不变。


* * @implSpec * The default implementation is equivalent to performing the following * steps for this {@code map}, then returning the current value or * {@code null} if now absent: * *

{@code

     * if (map.get(key) != null) {

     *     V oldValue = map.get(key);

     *     V newValue = remappingFunction.apply(key, oldValue);

     *     if (newValue != null)

     *         map.put(key, newValue);

     *     else

     *         map.remove(key);

     * }

     * }


* * 默认的实现等价于如下所示,如果没有默认值,则返回当前value或null:


* * if (map.get(key) != null) { * V oldValue = map.get(key); * V newValue = remappingFunction.apply(key, oldValue); * if (newValue != null) * map.put(key, newValue); * else * map.remove(key); * }


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. In particular, all implementations of * subinterface {@link java.util.concurrent.ConcurrentMap} must document * whether the function is applied once atomically only if the value is not * present.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。 * 特别地,子接口java.util.concurrent.ConcurrentMap的所有实现都必须记录该函数是否仅在原子的情况下才被应用,除非value不存在。


* * @param key key with which the specified value is to be associated * @param remappingFunction the function to compute a value * @return the new value associated with the specified key, or null if none * @throws NullPointerException if the specified key is null and * this map does not support null keys, or the * remappingFunction is null


* * 如果该map不支持key为null,传入null将抛出NullPointerException


* * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of the specified key or value * prevents it from being stored in this map * (optional)


* * 如果key或者value的类型不符合,抛出ClassCastException异常


* * @since 1.8 */ default V computeIfPresent(K key, BiFunctionremappingFunction) { Objects.requireNonNull(remappingFunction); V oldValue; if ((oldValue = get(key)) != null) { V newValue = remappingFunction.apply(key, oldValue); if (newValue != null) { put(key, newValue); return newValue; } else { remove(key); return null; } } else { return null; } } /** * Attempts to compute a mapping for the specified key and its current * mapped value (or {@code null} if there is no current mapping). For * example, to either create or append a {@code String} msg to a value * mapping: * *

{@code

     * map.compute(key, (k, v) -> (v == null) ? msg : v.concat(msg))}

* (Method {@link #merge merge()} is often simpler to use for such purposes.) * *


If the function returns {@code null}, the mapping is removed (or * remains absent if initially absent). If the function itself throws an * (unchecked) exception, the exception is rethrown, and the current mapping * is left unchanged.


* * 尝试用给定key和当前映射的value(如果没有映射,则为null)计算出一个新的映射关系。 * 例如,要创建或者追加一个String msg到一个value的映射:


* * map.compute(key, (k, v) -> (v == null) ? msg : v.concat(msg)) * (通常,merge方法用作这样的目标是比较简单的。)


* * 如果函数返回null,则移除映射(如果初始就没有值,那么现在仍然没有值)。 * 如果函数本身抛出一个(为检查的)异常,则会重新抛出异常,当前映射保持不变。


* * @implSpec * The default implementation is equivalent to performing the following * steps for this {@code map}, then returning the current value or * {@code null} if absent: * *

{@code

     * V oldValue = map.get(key);

     * V newValue = remappingFunction.apply(key, oldValue);

     * if (oldValue != null ) {

     *    if (newValue != null)

     *       map.put(key, newValue);

     *    else

     *       map.remove(key);

     * } else {

     *    if (newValue != null)

     *       map.put(key, newValue);

     *    else

     *       return null;

     * }

     * }


* * 默认的实现等价于如下所示,如果没有默认值,则返回当前value或null:


* * V oldValue = map.get(key); * V newValue = remappingFunction.apply(key, oldValue); * if (oldValue != null ) { * if (newValue != null) * map.put(key, newValue); * else * map.remove(key); * } else { * if (newValue != null) * map.put(key, newValue); * else * return null; * }


* *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. In particular, all implementations of * subinterface {@link java.util.concurrent.ConcurrentMap} must document * whether the function is applied once atomically only if the value is not * present.


* * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。 * 特别地,子接口java.util.concurrent.ConcurrentMap的所有实现都必须记录该函数是否仅在原子的情况下才被应用,除非value不存在。


* * @param key key with which the specified value is to be associated * @param remappingFunction the function to compute a value * @return the new value associated with the specified key, or null if none * @throws NullPointerException if the specified key is null and * this map does not support null keys, or the * remappingFunction is null


* * 如果该map不支持key为null,传入null将抛出NullPointerException


* * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of the specified key or value * prevents it from being stored in this map * (optional)


* * 如果key或value的类型不符合,抛出ClassCastException异常


* * @since 1.8 */ default V compute(K key, BiFunctionremappingFunction) { Objects.requireNonNull(remappingFunction); V oldValue = get(key); V newValue = remappingFunction.apply(key, oldValue); if (newValue == null) { // delete mapping if (oldValue != null || containsKey(key)) { // something to remove remove(key); return null; } else { // nothing to do. Leave things as they were. return null; } } else { // add or replace old mapping put(key, newValue); return newValue; } } /** * If the specified key is not already associated with a value or is * associated with null, associates it with the given non-null value. * Otherwise, replaces the associated value with the results of the given * remapping function, or removes if the result is {@code null}. This * method may be of use when combining multiple mapped values for a key. * For example, to either create or append a {@code String msg} to a * value mapping: * *

{@code

     * map.merge(key, msg, String::concat)

     * }

* *


If the function returns {@code null} the mapping is removed. If the * function itself throws an (unchecked) exception, the exception is * rethrown, and the current mapping is left unchanged.


* * 如果指定的key没有与一个value关联或者key的映射值是null,那么用给定的非空value和key进行关联。 * 否则,使用给定的remapping函数计算结果替换之前关联的value。如果计算结果为null,移除之前关联的value。 * 这个方法可能会用在当将多个映射值组合在一起。例如,要创建或者追加一个String msg到一个value的映射:


* * @implSpec * The default implementation is equivalent to performing the following * steps for this {@code map}, then returning the current value or * {@code null} if absent: * *

{@code

     * V oldValue = map.get(key);

     * V newValue = (oldValue == null) ? value :

     *              remappingFunction.apply(oldValue, value);

     * if (newValue == null)

     *     map.remove(key);

     * else

     *     map.put(key, newValue);

     * }

* * 默认的实现等价于如下所示,如果没有默认值,则返回当前value或null:


* V oldValue = map.get(key); * V newValue = (oldValue == null) ? value : * remappingFunction.apply(oldValue, value); * if (newValue == null) * map.remove(key); * else * map.put(key, newValue);


* * *


The default implementation makes no guarantees about synchronization * or atomicity properties of this method. Any implementation providing * atomicity guarantees must override this method and document its * concurrency properties. In particular, all implementations of * subinterface {@link java.util.concurrent.ConcurrentMap} must document * whether the function is applied once atomically only if the value is not * present. * * 默认实现不保证该方法的同步性或原子性属性。任何提供原子性保证的实现都必须重写此方法并记录其并发性。 * 特别地,子接口java.util.concurrent.ConcurrentMap的所有实现都必须记录该函数是否仅在原子的情况下才被应用,除非value不存在。


* * @param key key with which the resulting value is to be associated * @param value the non-null value to be merged with the existing value * associated with the key or, if no existing value or a null value * is associated with the key, to be associated with the key * @param remappingFunction the function to recompute a value if present * @return the new value associated with the specified key, or null if no * value is associated with the key * @throws UnsupportedOperationException if the {@code put} operation * is not supported by this map * (optional)


* * 如果该map不支持put操作将抛出异常UnsupportedOperationException


* * @throws ClassCastException if the class of the specified key or value * prevents it from being stored in this map * (optional)


* * 如果key的类型不符合,抛出ClassCastException异常


* * @throws NullPointerException if the specified key is null and this map * does not support null keys or the value or remappingFunction is * null


* * 如果该map不支持key为null,传入null将抛出NullPointerException


* * @since 1.8 */ default V merge(K key, V value, BiFunctionremappingFunction) { Objects.requireNonNull(remappingFunction); Objects.requireNonNull(value); V oldValue = get(key); V newValue = (oldValue == null) ? value : remappingFunction.apply(oldValue, value); if (newValue == null) { remove(key); } else { put(key, newValue); } return newValue; } }


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注编程语言JAVA频道!




本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程