`

LinkedList基本用法

    博客分类:
  • JAVA
 
阅读更多
LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用.
LinkedList的构造函数如下
1. public LinkedList():  ——生成空的链表
2. public LinkedList(Collection col):  复制构造函数
1、获取链表的第一个和最后一个元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2.   
  3. public class LinkedListTest{  
  4.   public static void main(String[] args) {  
  5.     LinkedList<String> lList = new LinkedList<String>();  
  6.     lList.add("1");  
  7.     lList.add("2");  
  8.     lList.add("3");  
  9.     lList.add("4");  
  10.     lList.add("5");  
  11.   
  12.   
  13.     System.out.println("链表的第一个元素是 : " + lList.getFirst());  
  14.     System.out.println("链表最后一个元素是 : " + lList.getLast());  
  15.   }  
  16. }  

2、获取链表元素  
[java] view plaincopy
 
  1. for (String str: lList) {  
  2.       System.out.println(str);  
  3.     }  
3、从链表生成子表
[java] view plaincopy
 
  1. List subl = lList.subList(14);  
  2.     System.out.println(subl);  
  3.     lst.remove(2);  
  4.     System.out.println(lst);  
  5.     System.out.println(lList);  
4、添加元素:添加单个元素
 如果不指定索引的话,元素将被添加到链表的最后.
public boolean add(Object element)
public boolean add(int index, Object element)
也可以把链表当初栈或者队列来处理:
public boolean addFirst(Object element)
public boolean addLast(Object element)
addLast()方法和不带索引的add()方法实现的效果一样.
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2.   
  3. public class LinkedListTest{  
  4.   public static void main(String[] a) {  
  5.     LinkedList list = new LinkedList();  
  6.     list.add("A");  
  7.     list.add("B");  
  8.     list.add("C");  
  9.     list.add("D");  
  10.     list.addFirst("X");  
  11.     list.addLast("Z");  
  12.     System.out.println(list);  
  13.   }  
  14. }  
5、删除元素
[java] view plaincopy
 
  1. public Object removeFirst()  
  2. public Object removeLast()  
  3. import java.util.LinkedList;  
  4.   
  5.   
  6. public class MainClass {  
  7.   public static void main(String[] a) {  
  8.   
  9.   
  10.     LinkedList list = new LinkedList();  
  11.     list.add("A");  
  12.     list.add("B");  
  13.     list.add("C");  
  14.     list.add("D");  
  15.     list.removeFirst();  
  16.     list.removeLast();  
  17.     System.out.println(list);  
  18.   }  
  19. }  
6、使用链表实现栈效果
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class MainClass {  
  3.   public static void main(String[] args) {  
  4.     StackL stack = new StackL();  
  5.     for (int i = 0; i < 10; i++)  
  6.       stack.push(i);  
  7.     System.out.println(stack.top());  
  8.     System.out.println(stack.top());  
  9.     System.out.println(stack.pop());  
  10.     System.out.println(stack.pop());  
  11.     System.out.println(stack.pop());  
  12.   }  
  13. }  
  14. class StackL {  
  15.   private LinkedList list = new LinkedList();  
  16.   public void push(Object v) {  
  17.     list.addFirst(v);  
  18.   }  
  19.   public Object top() {  
  20.     return list.getFirst();  
  21.   }  
  22.   public Object pop() {  
  23.     return list.removeFirst();  
  24.   }  
  25. }  
7、使用链表来实现队列效果
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class MainClass {  
  3.   public static void main(String[] args) {  
  4.     Queue queue = new Queue();  
  5.     for (int i = 0; i < 10; i++)  
  6.       queue.put(Integer.toString(i));  
  7.     while (!queue.isEmpty())  
  8.       System.out.println(queue.get());  
  9.   }  
  10. }  
  11. class Queue {  
  12.   private LinkedList list = new LinkedList();  
  13.   public void put(Object v) {  
  14.     list.addFirst(v);  
  15.   }  
  16.   public Object get() {  
  17.     return list.removeLast();  
  18.   }  
  19.   public boolean isEmpty() {  
  20.     return list.isEmpty();  
  21.   }  
  22. }  

8、将LinkedList转换成ArrayList

 

[java] view plaincopy
 
  1. ArrayList<String> arrayList = new ArrayList<String>(linkedList);  
  2.     for (String s : arrayList) {  
  3.       System.out.println("s = " + s);  
  4.     }  

 

9、删掉所有元素:清空LinkedList
    lList.clear();
10、删除列表的首位元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class Main {  
  3.   public static void main(String[] args) {  
  4.     LinkedList<String> lList = new LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println(lList);  
  11.         //元素在删除的时候,仍然可以获取到元素  
  12.     Object object = lList.removeFirst();  
  13.     System.out.println(object + " has been removed");  
  14.     System.out.println(lList);  
  15.     object = lList.removeLast();  
  16.     System.out.println(object + " has been removed");  
  17.     System.out.println(lList);  
  18.   }  
  19. }  
11、根据范围删除列表元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class Main {  
  3.   public static void main(String[] args) {  
  4.     LinkedList<String> lList = new LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println(lList);  
  11.     lList.subList(25).clear();  
  12.     System.out.println(lList);  
  13.   }  
  14. }  
12、删除链表的特定元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class Main {  
  3.   public static void main(String[] args) {  
  4.     LinkedList<String> lList = new LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println(lList);  
  11.     System.out.println(lList.remove("2"));//删除元素值=2的元素  
  12.     System.out.println(lList);  
  13.     Object obj = lList.remove(2);  //删除第二个元素  
  14.     System.out.println(obj + " 已经从链表删除");  
  15.     System.out.println(lList);  
  16.   }  
  17. }  
13、将LinkedList转换为数组,数组长度为0
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. import java.util.List;  
  3. public class Main {  
  4.   public static void main(String[] args) {  
  5.     List<String> theList = new LinkedList<String>();  
  6.     theList.add("A");  
  7.     theList.add("B");  
  8.     theList.add("C");  
  9.     theList.add("D");  
  10.     String[] my = theList.toArray(new String[0]);  
  11.     for (int i = 0; i < my.length; i++) {  
  12.       System.out.println(my[i]);  
  13.     }  
  14.   }  
  15. }  
14、将LinkedList转换为数组,数组长度为链表长度
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. import java.util.List;  
  3. public class Main {  
  4.   public static void main(String[] args) {  
  5.     List<String> theList = new LinkedList<String>();  
  6.     theList.add("A");  
  7.     theList.add("B");  
  8.     theList.add("C");  
  9.     theList.add("D");  
  10.     String[] my = theList.toArray(new String[theList.size()]);  
  11.     for (int i = 0; i < my.length; i++) {  
  12.       System.out.println(my[i]);  
  13.     }  
  14.   }  
  15. }  
15、将LinkedList转换成ArrayList
[java] view plaincopy
 
  1. import java.util.ArrayList;  
  2. import java.util.LinkedList;  
  3. import java.util.List;  
  4. public class Main {  
  5.   public static void main(String[] args) {  
  6.     LinkedList<String> myQueue = new LinkedList<String>();  
  7.     myQueue.add("A");  
  8.     myQueue.add("B");  
  9.     myQueue.add("C");  
  10.     myQueue.add("D");  
  11.     List<String> myList = new ArrayList<String>(myQueue);  
  12.     for (Object theFruit : myList)  
  13.       System.out.println(theFruit);  
  14.   }  
  15. }  
16、实现栈
[java] view plaincopy
 
  1. import java.util.Collections;  
  2. import java.util.LinkedList;  
  3. public class Main {  
  4.   public static void main(String[] argv) throws Exception {  
  5.     LinkedList stack = new LinkedList();  
  6.     Object object = "";  
  7.     stack.addFirst(object);  
  8.     Object o = stack.getFirst();  
  9.     stack = (LinkedList) Collections.synchronizedList(stack);  
  10.   }  
  11. }  
17、实现队列
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. public class Main {  
  3.   public static void main(String[] argv) throws Exception {  
  4.     LinkedList queue = new LinkedList();  
  5.     Object object = "";  
  6.     // Add to end of queue  
  7.     queue.add(object);  
  8.     // Get head of queue  
  9.     Object o = queue.removeFirst();  
  10.   }  
  11. }  
18 、同步方法
[java] view plaincopy
 
  1. import java.util.Collections;  
  2. import java.util.LinkedList;  
  3. public class Main {  
  4.   public static void main(String[] argv) throws Exception {  
  5.     LinkedList queue = new LinkedList();  
  6.     Object object = "";  
  7.     queue.add(object);  
  8.     Object o = queue.removeFirst();  
  9.     queue = (LinkedList) Collections.synchronizedList(queue);  
  10.   }  
  11. }  
19、查找元素位置
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2.   
  3. public class Main {  
  4.   public static void main(String[] args) {  
  5.     LinkedList<String> lList = new LinkedList<String>();  
  6.     lList.add("1");  
  7.     lList.add("2");  
  8.     lList.add("3");  
  9.     lList.add("4");  
  10.     lList.add("5");  
  11.     lList.add("2");  
  12.     System.out.println(lList.indexOf("2"));  
  13.     System.out.println(lList.lastIndexOf("2"));  
  14.   }  
  15. }  
20、替换元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2.   
  3. public class Main {  
  4.   public static void main(String[] args) {  
  5.     LinkedList<String> lList = new LinkedList<String>();  
  6.     lList.add("1");  
  7.     lList.add("2");  
  8.     lList.add("3");  
  9.     lList.add("4");  
  10.     lList.add("5");  
  11.     System.out.println(lList);  
  12.     lList.set(3"Replaced");//使用set方法替换元素,方法的第一个参数是元素索引,后一个是替换值  
  13.     System.out.println(lList);  
  14.   }  
  15. }  
21、链表添加对象
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2. class Address {  
  3.   private String name;  
  4.   private String street;  
  5.   private String city;  
  6.   private String state;  
  7.   private String code;  
  8.   Address(String n, String s, String c, String st, String cd) {  
  9.     name = n;  
  10.     street = s;  
  11.     city = c;  
  12.     state = st;  
  13.     code = cd;  
  14.   }  
  15.   public String toString() {  
  16.     return name + " " + street + " " + city + " " + state + " " + code;  
  17.   }  
  18. }  
  19.   
  20.   
  21. class MailList {  
  22.   public static void main(String args[]) {  
  23.     LinkedList<Address> ml = new LinkedList<Address>();  
  24.     ml.add(new Address("A""11 Ave""U""IL""11111"));  
  25.     ml.add(new Address("R""11 Lane""M""IL""22222"));  
  26.     ml.add(new Address("T""8 St""C""IL""33333"));  
  27.     for (Address element : ml)  
  28.       System.out.println(element + "\n");  
  29.   }  
  30. }  
22、确认链表是否存在特定元素
[java] view plaincopy
 
  1. import java.util.LinkedList;  
  2.   
  3.   
  4. public class Main {  
  5.   public static void main(String[] args) {  
  6.     LinkedList<String> lList = new LinkedList<String>();  
  7.     lList.add("1");  
  8.     lList.add("2");  
  9.     lList.add("3");  
  10.     lList.add("4");  
  11.     lList.add("5");  
  12.     if (lList.contains("4")) {  
  13.       System.out.println("LinkedList contains 4");  
  14.     } else {  
  15.       System.out.println("LinkedList does not contain 4");  
  16.     }  
  17.   }  
  18. }  
23、根据链表元素生成对象数组
[java] view plaincopy
 
  1. Object[] objArray = lList.toArray();  
  2. for (Object obj: objArray) {  
  3.    System.out.println(obj);  
  4. }  
24、链表多线程
[java] view plaincopy
 
  1. import java.util.Collections;  
  2. import java.util.LinkedList;  
  3. import java.util.List;  
  4. class PrepareProduction implements Runnable {  
  5.   private final List<String> queue;  
  6.   PrepareProduction(List<String> q) {  
  7.     queue = q;  
  8.   }  
  9.   public void run() {  
  10.     queue.add("1");  
  11.     queue.add("done");  
  12.   }  
  13. }  
  14. class DoProduction implements Runnable {  
  15.   private final List<String> queue;  
  16.   DoProduction(List<String> q) {  
  17.     queue = q;  
  18.   }  
  19.   public void run() {  
  20.     String value = queue.remove(0);  
  21.     while (!value.equals("*")) {  
  22.       System.out.println(value);  
  23.       value = queue.remove(0);  
  24.     }  
  25.   }  
  26. }  
  27. public class Main {  
  28.   public static void main(String[] args) throws Exception {  
  29.     List q = Collections.synchronizedList(new LinkedList<String>());  
  30.     Thread p1 = new Thread(new PrepareProduction(q));  
  31.     Thread c1 = new Thread(new DoProduction(q));  
  32.     p1.start();  
  33.     c1.start();  
  34.     p1.join();  
  35.     c1.join();  
  36.   }  
  37. }  
25、优先级链表(来自JBOSS)
[java] view plaincopy
 
  1. import java.util.ArrayList;  
  2. import java.util.LinkedList;  
  3. import java.util.List;  
  4. import java.util.ListIterator;  
  5. import java.util.NoSuchElementException;  
  6.   
  7.   
  8. public class BasicPriorityLinkedList {  
  9.   
  10.   
  11.   protected LinkedList[] linkedLists;  
  12.   protected int priorities;  
  13.   protected int size;  
  14.   
  15.   
  16.   public BasicPriorityLinkedList(int priorities) {  
  17.     this.priorities = priorities;  
  18.     initDeques();  
  19.   }  
  20.   public void addFirst(Object obj, int priority) {  
  21.     linkedLists[priority].addFirst(obj);  
  22.     size++;  
  23.   }  
  24.   public void addLast(Object obj, int priority) {  
  25.     linkedLists[priority].addLast(obj);  
  26.     size++;  
  27.   }  
  28.   public Object removeFirst() {  
  29.     Object obj = null;  
  30.     for (int i = priorities - 1; i >= 0; i--) {  
  31.       LinkedList ll = linkedLists[i];  
  32.       if (!ll.isEmpty()) {  
  33.         obj = ll.removeFirst();  
  34.         break;  
  35.       }  
  36.     }  
  37.     if (obj != null) {  
  38.       size--;  
  39.     }  
  40.     return obj;  
  41.   }  
  42.   public Object removeLast() {  
  43.     Object obj = null;  
  44.     for (int i = 0; i < priorities; i++) {  
  45.       LinkedList ll = linkedLists[i];  
  46.       if (!ll.isEmpty()) {  
  47.         obj = ll.removeLast();  
  48.       }  
  49.       if (obj != null) {  
  50.         break;  
  51.       }  
  52.     }  
  53.     if (obj != null) {  
  54.       size--;  
  55.     }  
  56.     return obj;  
  57.   }  
  58.   
  59.   
  60.   public Object peekFirst() {  
  61.     Object obj = null;  
  62.     for (int i = priorities - 1; i >= 0; i--) {  
  63.       LinkedList ll = linkedLists[i];  
  64.       if (!ll.isEmpty()) {  
  65.         obj = ll.getFirst();  
  66.       }  
  67.       if (obj != null) {  
  68.         break;  
  69.       }  
  70.     }  
  71.     return obj;  
  72.   }  
  73.   
  74.   
  75.   public List getAll() {  
  76.     List all = new ArrayList();  
  77.     for (int i = priorities - 1; i >= 0; i--) {  
  78.       LinkedList deque = linkedLists[i];  
  79.       all.addAll(deque);  
  80.     }  
  81.     return all;  
  82.   }  
  83.   
  84.   
  85.   public void clear() {  
  86.     initDeques();  
  87.   }  
  88.   
  89.   
  90.   public int size() {  
  91.     return size;  
  92.   }  
  93.   
  94.   
  95.   public boolean isEmpty() {  
  96.     return size == 0;  
  97.   }  
  98.   
  99.   
  100.   public ListIterator iterator() {  
  101.     return new PriorityLinkedListIterator(linkedLists);  
  102.   }  
  103.   
  104.   
  105.   protected void initDeques() {  
  106.     linkedLists = new LinkedList[priorities];  
  107.     for (int i = 0; i < priorities; i++) {  
  108.       linkedLists[i] = new LinkedList();  
  109.     }  
  110.     size = 0;  
  111.   }  
  112.   
  113.   
  114.   class PriorityLinkedListIterator implements ListIterator {  
  115.     private LinkedList[] lists;  
  116.     private int index;  
  117.     private ListIterator currentIter;  
  118.     PriorityLinkedListIterator(LinkedList[] lists) {  
  119.       this.lists = lists;  
  120.       index = lists.length - 1;  
  121.       currentIter = lists[index].listIterator();  
  122.     }  
  123.   
  124.   
  125.     public void add(Object arg0) {  
  126.       throw new UnsupportedOperationException();  
  127.     }  
  128.   
  129.   
  130.     public boolean hasNext() {  
  131.       if (currentIter.hasNext()) {  
  132.         return true;  
  133.       }  
  134.       while (index >= 0) {  
  135.         if (index == 0 || currentIter.hasNext()) {  
  136.           break;  
  137.         }  
  138.         index--;  
  139.         currentIter = lists[index].listIterator();  
  140.       }  
  141.       return currentIter.hasNext();  
  142.     }  
  143.   
  144.   
  145.     public boolean hasPrevious() {  
  146.       throw new UnsupportedOperationException();  
  147.     }  
  148.   
  149.   
  150.     public Object next() {  
  151.       if (!hasNext()) {  
  152.         throw new NoSuchElementException();  
  153.       }  
  154.       return currentIter.next();  
  155.     }  
  156.   
  157.   
  158.     public int nextIndex() {  
  159.       throw new UnsupportedOperationException();  
  160.     }  
  161.   
  162.   
  163.     public Object previous() {  
  164.       throw new UnsupportedOperationException();  
  165.     }  
  166.   
  167.   
  168.     public int previousIndex() {  
  169.       throw new UnsupportedOperationException();  
  170.     }  
  171.   
  172.   
  173.     public void remove() {  
  174.       currentIter.remove();  
  175.       size--;  
  176.     }  
  177.   
  178.   
  179.     public void set(Object obj) {  
  180.       throw new UnsupportedOperationException();  
  181.     }  
  182.   }  
  183.   
  184.   
  185. }  
26、生成list的帮助类(来自google)
[java] view plaincopy
 
  1. import java.util.ArrayList;  
  2. import java.util.Collections;  
  3. import java.util.LinkedList;  
  4. import java.util.List;  
  5. public class Lists {  
  6.   private Lists() { }  
  7.   public static <E> ArrayList<E> newArrayList() {  
  8.     return new ArrayList<E>();  
  9.   }  
  10.   public static <E> ArrayList<E> newArrayListWithCapacity(int initialCapacity) {  
  11.     return new ArrayList<E>(initialCapacity);  
  12.   }  
  13.   public static <E> ArrayList<E> newArrayList(E... elements) {  
  14.     ArrayList<E> set = newArrayList();  
  15.     Collections.addAll(set, elements);  
  16.     return set;  
  17.   }  
  18.   public static <E> ArrayList<E> newArrayList(Iterable<? extends E> elements) {  
  19.     ArrayList<E> list = newArrayList();  
  20.     for(E e : elements) {  
  21.       list.add(e);  
  22.     }  
  23.     return list;  
  24.   }  
  25.   public static <E> LinkedList<E> newLinkedList() {  
  26.     return new LinkedList<E>();  
  27.   }  
  28. }  
  29.    
分享到:
评论

相关推荐

    Java数据存储类型ArrayList、HashSet、HashMap、LinkedList使用不同遍历方法效率研究By Python

    Java不同数据存储类型使用不同遍历方法效率研究 GitHub代码仓库 数据存储类型 ArrayList HashSet HashMap LinkedList 遍历方法 传统遍历方法 for(int i=0;i&lt;list.size();i++) { String str = list.get(i); ... ...

    ClassRosterList:基本的LinkedList程序添加和删除元素,使用增强的for循环和排序方法

    ClassRosterList 基本的LinkedList程序添加和删除元素,使用增强的for循环和排序方法。

    Python+单链表的基本操作代码

    使用Python编程链表数据结构,可以使用类来实现单链表的基本操作,如下所示: # 这个程序定义了两个类:Node和LinkedList。 # Node类用于表示单链表中的每个节点,包含数据和指向下一个节点的指针。 # LinkedList类...

    突破程序员基本功的16课.part2

    4.4.7 尽量不要使用finalize方法 4.4.8 考虑使用SoftReference 4.5 小结 第5课 表达式中的陷阱 5.1 关于字符串的陷阱 5.1.1 JVM对字符串的处理 5.1.2 不可变的字符串 5.1.3 字符串比较 5.2 表达式类型的...

    LinkedList-MIPS:使用 MIPS 实现链表

    用户也可以使用调试方法打印出整个链表。 输入字符串的当前限制少于 11 个字符。 这可以根据新节点的空间分配轻松更改(即使这也意味着更改许多过程的偏移量)。 我遇到的问题是这种链表实现存在内存泄漏。 如果用...

    实验05 Java集合.doc

    2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合中添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印...

    Java学习笔记

    2、多次使用的相同变量最好归纳成常量,3、尽量少的在循环中执行方法调用,4、常量的定义可以放到接口中,5、ArrayList和LinkedList的选择, 6、String,StringBuffer和StringBuilder, 7、包装类和基本类型的选择...

    CodingPractices:为简单实践编写的一些代码,例如斐波那契或简单数据算法

    概述 该存储库存储短代码段(&lt;1k行),用于简单的编码实践和个人使用。 这里的大多数代码(当前全部)都是用Java编写...该代码以Java语言编写,是LinkedList的简单实现,具有创建,删除或反转LinkedList的基本方法。

    华为java经典面试题大总结

    1 面向对象的特征有哪些方面 ...通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。

    think in java线程和容器2

    java线程中容器使用技术,比如List接口是在Collection的基础上添加了大量方法,有两种基本类型:ArrayList,它擅⻓于随机访问元素,但是List中间插入或移除元 素时较慢;LinkedList,它和ArrayList的特性正好相反。...

    收集高频Java面试题以及面试时候被问到的面试题.rar

    如果不断改变基本功能并且使用接口,那么就需要改变所有实现了该接口的类。 List、Set、Map的区别 1. List 可存储重复对象; 是一个有序集合,保存了每一个元素的插入顺序,输出顺序就是插入顺序; 常见的实现类有...

    【Java面试+Java学习指南】 一份涵盖大部分Java程序员所需要掌握的核心知识

    Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解2:Queue和LinkedList Java集合详解3:Iterator,fail-fast机制与比较器 Java集合详解4:HashMap和HashTable Java集合详解5:深入...

    Java面试经典题,对JAVA面试很有帮助

    3.八种基本数据类型的大小,以及他们的封装类 4.标识符的命名规则 5.instanceof 关键字的作用 6.Java自动装箱与拆箱 7.重载和重写的区别 8.equals与==的区别 9.Hashcode的作用 10.String、String StringBuffer 和 ...

    清华妹子的Java仓库(进阶学习路线)

    JNA:演示了JNA的基本用法,使用Java调用C++代码。 博客目录 Java基础 Java基础学习(1)——引用 Java基础学习(2)——注解 Java基础学习(3)——泛型 Java基础学习(4)——动态代理 《Java多线程核心技术》读书笔记 ...

    Java工程师面试复习指南

    Java集合详解:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解:Queue和LinkedList Java集合详解:迭代器,快速失败机制与比较器 Java集合详解:HashMap和HashTable Java集合详解:深入理解...

    Java集合总结.txt

    单个集合的学习路线:使用-&gt;做实验-&gt;画图-&gt;分析源码 集合:大小可变的序列,只能存放对象 集合和数组的区别: 1.集合是大小可变的序列,数组在声明后,长度不可变 2.数组只能存放声明时指定的一种数据类型,集合...

    看了程序人生一篇文章:如何实现可以获取最小值的栈。自己思考,实现了一下

    近来学习了java,对数据结构很感兴趣。...深入学了一下LinkedList,TreeMap的用法和方法,实现了基本的入栈和弹栈的功能,并能输出栈中的最小值。 半下午,写出来了心里很高兴,就分享在这里,还请指导。。。

    Java 基础核心总结 +经典算法大全.rar

    反射的思想及作用 反射的基本使用 获取类的 Class 对象构造类的实例化对象获取-个类的所有信息 获取类中的变量(Field) 获取类中的方法(Method) 获取类的构造器(Constructor) 获取注解 通过反射调用方法反射的应用...

    Java后端面试问题整理.docx

    • 熟悉Java多线程并发中线程基本方法,线程池,线程生命周期,熟悉Java锁中常见锁分类(乐观/悲观锁、自旋锁、独/共享锁、可重入锁、公平/非公平锁、分段锁、偏向锁,轻/重量级锁)和基本的锁升级策略

Global site tag (gtag.js) - Google Analytics