preface

For the record, this article uses JDK1.8

Review of previous chapters:

  • The Collection overview
  • List collection is as simple as that.
  • Map sets, hash tables, and red-black trees
  • HashMap is as simple as this
  • LinkedHashMap is as simple as this

This article focuses on TreeMap

It is best to have a little data structure foundation before reading this article:

  • Java implements one-way linked lists
  • Stacks and queues are that simple
  • Binary trees are that simple

Of course, if there is something wrong, please bear with me and correct me in the comments

I. TreeMap analysis

As usual, I have simply translated the comments at the top (my English is poor, please bear with me if there are any mistakes ~ please correct them in the comments section).

Next, let’s look at the class inheritance diagram:

Let me summarize the points mentioned in the notes:

  • TreeMap implements the NavigableMap interface, and the NavigableMap interface inherits the SortedMap interface, making our TreeMap orderly!
  • The bottom layer of TreeMap is a red-black tree, and the time complexity of its methods is not too high :log(n)~
  • asynchronous
  • Use Comparator or Comparable to compare keys for equality and sort ~

Comparator and Comparable are pretty much forgotten for me. Let’s take a look at the TreeMap source code to see how it works and review the use of Comparator and Comparable.

1.1 TreeMap domain

1.2TreeMap construction method

TreeMap can be constructed in four ways:

You can see that most of the TreeMap constructors are related to comparators:

The TreeMap order is compared using the Comparator. If the Comparator is null, the natural order is used

For example:

  • If value is an integer, the natural order refers to the order in which we normally sort (1,2,3,4,5..). ~

    TreeMap<Integer, Integer> treeMap = new TreeMap<>();

    treeMap.put(1.5);
    treeMap.put(2.4);
    treeMap.put(3.3);
    treeMap.put(4.2);
    treeMap.put(5.1);

    for (Entry<Integer, Integer> entry : treeMap.entrySet()) {

        String s = entry.getKey() +"Java3y---->" + entry.getValue();

        System.out.println(s);
    }
Copy the code

1.3 put method

Let’s take a look at TreeMap’s core PUT method and read it to learn a lot about TreeMap’s features

Here is compare(Object k1, Object k2)


    /** * Compares two keys using the correct comparison method for this TreeMap. */
    @SuppressWarnings("unchecked")
    final int compare(Object k1, Object k2) {
        return comparator==null ? ((Comparable<? super K>)k1).compareTo((K)k2)
            : comparator.compare((K)k1, (K)k2);
    }
Copy the code

If we set the key to null, an exception will be thrown and the following code will not be executed.

1.4 the get method

Let’s look at the implementation of the get method:

Click on getEntry() to see the implementation:

If the “getEntryUsingComparator” is not null, what is the “getEntryUsingComparator” (Object key)

1.5 the remove method

The deleteEntry(Entry

p) method is called when a node is deleted. This method deletes the node and balances the red-black tree
,v>

Balancing red-black tree code is more complex, I will not say, you go to see (anyway I do not understand)….

1.6 Traversal method

If you look at the source code, you may not know which is the core traversal method, because there are many, many Iterator methods

At this point, we just need to debug it and follow along!

As a result, TreeMap traversal uses the EntryIterator inner class

Let’s start by looking at the EntryIterator class structure diagram:

As you can see, most implementations of EntryIterator are in their parent classes:

Let’s take a look at the more important methods of PrivateEntryIterator:

Let us go into the succeeded (e) method to see the implementation:

The next node of a node, the next node in order. As you can see from the code, the smallest node in the right subtree is returned if the right subtree is not empty. If the right subtree is empty, we’re going to go back up. In this case, t is the last node of the tree that it’s rooted in. If it’s the left child of its parent, then the parent is its next node, otherwise, t is the last node in the tree rooted in its parent, and you have to go back up again. Until CH is the left child of P.

Source: blog.csdn.net/on_1y/artic…

Second, the summary

The underlying layer of TreeMap is a red-black tree, which implements the order of the Map set ~

If a Comparator object is passed in the constructor, the comparison is made to the method of the Comparator object. Otherwise, the Comparable compareTo(T O) method is used for comparison.

  • It’s worth noting that if you usecompareTo(T o)Methods to compare,The key must not be nullAnd have to implement the Comparable interface.
  • Even if the Comparator object is passed in, nocompareTo(T o)Method to compare, keyIs alsoCannot be null

    public static void main(String[] args) {
        TreeMap<Student, String> map = new TreeMap<Student, String>((o1, o2) -> {
            // Main conditions
            int num = o1.getAge() - o2.getAge();

            // Secondary condition
            int num2 = num == 0 ? o1.getName().compareTo(o2.getName()) : num;

            return num2;
        });

        // Create a student object
        Student s1 = new Student("M. pei".30);
        Student s2 = new Student("Liu Xia-hui".35);

        // Add an element to the collection
        map.put(s1, "In the song dynasty");
        map.put(s2, "The yuan dynasty");
        map.put(null."Han dynasty");

        // Get the key set
        Set<Student> set = map.keySet();

        // iterate over the key set
        for (Student student : set) {
            String value = map.get(student);
            System.out.println(student + "-- -- -- -- -- -- -- -- --"+ value); }}Copy the code

Comparator and Comparable appear quite frequently in many places in the source code, because TreeMap implements order by either passing in Comparator objects or using the Comparable interface with the default key.

Let me conclude by summarizing TreeMap’s main points:

  1. Since the bottom layer is a red-black tree, the time is guaranteed to be log(n).
  2. The key cannot be null. A NullPointException is thrown if the key is null
  3. To customize the comparison, pass in the Comparator object in the constructor, otherwise use the natural ordering of keys for the comparison
  4. TreeMap is not synchronous, and you can use Collections to encapsulate synchronization

References:

  • “The Core Java”
  • Blog.csdn.net/panweiwei19…
  • www.cnblogs.com/chinajava/p…

Tomorrow, if nothing else, the ConcurrentHashMap collection will be written, so stay tuned to ~~~~

The article directory navigation: zhongfucheng.bitcron.com/post/shou-j…

If the article has the wrong place welcome to correct, everybody exchanges with each other. Students who are used to reading technical articles on wechat and want to get more Java resources can follow the wechat public account :Java3y. Thanks for your support! I hope I can introduce to other friends in need