【Java心得总结六】Java容器中——Collection

在【Java心得总结五】Java容器上——容器初探这篇博文中,我对Java容器类库从一个整体的偏向于宏观的角度初步认识了Java容器类库。而在这篇博文中,我想着重对容器类库中的Collection容器做一个着重的探索与总结。

Collection:一个独立元素的序列,这些元素都服从一条或多条规则。(注:Collection其实就是将一组数据对象按照一维线性的方式组织起来)List必须按照插入的顺序保存元素,而set不能有重复元素。Queue按照排队规则来确定对象产生的顺序(通常与它们被插入的顺序相同)。

废话不说先上图!

Java容器类库

——摘自《Thinking in java》

从上图中我们可以看出Collection是Java类库中的一个大的子模块,它主要包含了:List和Set两部分

一、List接口

Java中List可以将元素维护在特定的序列中(这里元素既可以是基本类型也可以自定义类【Java心得总结一】Java基本类型和包装类型解析)

List接口主要有两种实现类型:

  • 基本的ArrayList,它长于随机访问元素,但是在List的中间插入和移除元素时较慢
  • LinkedList,它通过代价较低的在List中间进行的插入和删除操作,提供了优化的顺序访问。LinkedList在随机访问方面相对比较慢。

(二者的关系基本就是数据机构中我们学过的顺序存储结构和链表的关系)

ArrayList:

声明:

 1 import java.util.ArrayList;
 2 import java.util.List;
 3 
 4 class MyClass{}
 5 
 6 public class ArrayListTest{
 7   // 声明存放整数的列表,这里必须用包装器类型  
 8   List<Integer> l1 = new ArrayList<Integer>();  
 9   // 声明存放自定义类的列表  
10   List<MyClass>  l2 = new ArrayList<MyClass>();
11   // 也可以像这样不给出类型参数,编译器会在向l3中加入元素的时候进行判定  
12   List l3 = new ArrayList();  
13 }

声明一个List容器的时候,用到了泛型的知识(【Java心得总结三】Java泛型上——初识泛型和【Java心得总结四】Java泛型下——万恶的擦除)

还有一点有趣的是,我们声明了ArrayList对象,却将引用赋值给了List引用,从上面图中可以看出ArrayList是List接口的实现,所以我们用List引用来持有ArrayList对象是完全可行的。

方法:

add()将元素添加到列表中(这是最常用的方法之一,当然了添加的元素类型必须是同一类型或者说继承自相同基类的类型
contains()确定某个对象是否在列表中
remove()将某一个对象的引用传递给remove方法,即可移除列表中的一个对象
indexOf()持有一个对象的引用,则利用该方法可以获得其在列表中的编号
equals()该方法是Object基类中的一个方法remove方法在删除元素时要要用到这个方法进行匹配
subList()该方法允许你从较大的列表中创出一个片段
retainAll()   该方法是一种有效的交集操作
removeAll()移除List中的所有元素
get()取得指定索引位置的元素

 

 

 

 

 

 

 

代码示例:

 1 //: holding/ListFeatures.java 
 2 import java.util.*;
 3 
 4 public class ArrayListTest {
 5     public static void main(String[] args) {
 6         Random rand = new Random(47);
 7         List<String> ls = new ArrayList<String>();
 8         ls.add("s1");
 9         ls.add("s2");
10         ls.add("s3");
11         ls.add("s4");
12         ls.add("s5");
13         System.out.println("1: " + ls);
14         String s6 = new String("s6");
15         ls.add(s6); // Automatically resizes
16         System.out.println("2: " + ls);
17         System.out.println("3: " + ls.contains(s6));
18         ls.remove(s6); // Remove by object
19         String s3 = ls.get(2);
20         System.out.println("4: " + s3 + " " + ls.indexOf(s3));
21         String s7 = new String();
22         System.out.println("5: " + ls.indexOf(s7));
23         System.out.println("6: " + ls.remove(s7));
24         // Must be the exact object:
25         System.out.println("7: " + ls.remove(s3));
26         System.out.println("8: " + ls);
27         ls.add(3, new String("s8")); // Insert at an index
28         System.out.println("9: " + ls);
29         List<String> sub = ls.subList(1, 4);
30         System.out.println("subList: " + sub);
31         System.out.println("10: " + ls.containsAll(sub));
32         Collections.sort(sub); // In-place sort
33         System.out.println("sorted subList: " + sub);
34         // Order is not important in containsAll():
35         System.out.println("11: " + ls.containsAll(sub));
36         Collections.shuffle(sub, rand); // Mix it up
37         System.out.println("shuffled subList: " + sub);
38         System.out.println("12: " + ls.containsAll(sub));
39         List<String> copy = new ArrayList<String>(ls);
40         sub = Arrays.asList(ls.get(1), ls.get(4));
41         System.out.println("sub: " + sub);
42         copy.retainAll(sub);
43         System.out.println("13: " + copy);
44         copy = new ArrayList<String>(ls); // Get a fresh copy
45         copy.remove(2); // Remove by index
46         System.out.println("14: " + copy);
47         copy.removeAll(sub); // Only removes exact objects
48         System.out.println("15: " + copy);
49         copy.set(1, new String("s9")); // Replace an element
50         System.out.println("16: " + copy);
51         copy.addAll(2, sub); // Insert a list in the middle
52         System.out.println("17: " + copy);
53         System.out.println("18: " + ls.isEmpty());
54         ls.clear(); // Remove all elements
55         System.out.println("19: " + ls);
56         System.out.println("20: " + ls.isEmpty());
57         List newLs = new ArrayList<String>();
58         newLs.add("newS1");
59         newLs.add("newS2");
60         newLs.add("newS3");
61         newLs.add("newS4");
62         newLs.add("newS5");
63         ls.addAll(newLs);
64         System.out.println("21: " + ls);
65         Object[] o = ls.toArray();
66         System.out.println("22: " + o[3]);
67         String[] str = ls.toArray(new String[0]);
68         System.out.println("23: " + str[3]);
69     }
70 }
71 /*
72 1: [s1, s2, s3, s4, s5]
73 2: [s1, s2, s3, s4, s5, s6]
74 3: true
75 4: s3 2
76 5: -1
77 6: false
78 7: true
79 8: [s1, s2, s4, s5]
80 9: [s1, s2, s4, s8, s5]
81 subList: [s2, s4, s8]
82 10: true
83 sorted subList: [s2, s4, s8]
84 11: true
85 shuffled subList: [s4, s2, s8]
86 12: true
87 sub: [s4, s5]
88 13: [s4, s5]
89 14: [s1, s4, s8, s5]
90 15: [s1, s8]
91 16: [s1, s9]
92 17: [s1, s9, s4, s5]
93 18: false
94 19: []
95 20: true
96 21: [newS1, newS2, newS3, newS4, newS5]
97 22: newS4
98 23: newS4
99 *///:~

上面的代码我们以String作为List容器的存储对象,基本涵盖了所有基本的ArrayList操作。

我们在代码36行使用了Collections的shuffle方法,它的作用就是将容器中的元素打乱。

LinkedList

正如我们前面提到的,像ArrayList一样LinkedList也实现了基本的List接口,但是在某些方面它要比ArrayList要高效一些,如插入和移除操作,但是在随机访问方面要逊色一些。

另外LinkedList还有一个重要的作用是用来实现栈、队列以及双端队列等数据结构中的一些基本结构

声明:

 1 import java.util.*;
 2 class MyClass{}
 3 public class LinkedListTest {
 4     // 声明持有String类型的列表,同样这里我们可以用List来持有LinkedList的引用
 5     List<String> ls = new LinkedList<String>();
 6     // 声明持有自定义类型的列表
 7     List<MyClass> lsm = new LinkedList<MyClass>();
 8     // 同样我们可以用LinkedList的引用来持有它
 9     LinkedList<String> lss = new LinkedList<String>();
10     // 同ArrayList一样我们也可以并不在声明时赋以类型参数,而再赋值时再确定
11     List l = new LinkedList();
12 }

上面的声明方式同ArrayList是基本一样的,我们可以利用List接口来持有LinkedList对象的引用,同样也可以用LinkedList自己来持有这个引用

方法:

因为LinkedList也实现了List接口,当然上面ArrayList中的方法也都包含,除此之外它还包含如下方法

getFirst()返回列表的头(第一个元素),而不移除它。如果List为空则抛出NoSuchElementException
element()同getFirst()
peek()与前两个方法的唯一区别是,如果List为空则返回null
removeFirst()  移除并返回列表头,如果List为空,同上抛出相同的异常
remove()同removeFirst()
poll()与前两个方法的唯一区别是,如果List为空则返回null
addFirst()将某个元素插入到列表头部
addLast()将某个元素插入到列表尾部
add()同addLast()
removeLast移除并返回列表的最后一个元素

 

 

 

 

 

 

 

 

代码示例

 1 import java.util.*;
 2 
 3 public class LinkedListTest {
 4     public static void main(String[] args) {
 5         LinkedList<String> ls = new LinkedList<String>();
 6         ls.add("s1");
 7         ls.addFirst("s2");
 8         ls.addLast("s3");
 9         System.out.println(ls);
10         // Identical:
11         System.out.println("ls.getFirst(): " + ls.getFirst());
12         System.out.println("ls.element(): " + ls.element());
13         // Only differs in empty-list behavior:
14         System.out.println("ls.peek(): " + ls.peek());
15         // Identical; remove and return the first element:
16         System.out.println("ls.remove(): " + ls.remove());
17         System.out.println("ls.removeFirst(): " + ls.removeFirst());
18         // Only differs in empty-list behavior:
19         System.out.println("ls.poll(): " + ls.poll());
20         System.out.println(ls);
21         ls.addFirst(new String("s4"));
22         System.out.println("After addFirst(): " + ls);
23         ls.offer(new String("s5"));
24         System.out.println("After offer(): " + ls);
25         ls.add(new String("s6"));
26         System.out.println("After add(): " + ls);
27         ls.addLast(new String("s7"));
28         System.out.println("After addLast(): " + ls);
29         System.out.println("ls.removeLast(): " + ls.removeLast());
30     }
31 }
32 /*
33 [s2, s1, s3]
34 ls.getFirst(): s2
35 ls.element(): s2
36 ls.peek(): s2
37 ls.remove(): s2
38 ls.removeFirst(): s1
39 ls.poll(): s3
40 []
41 After addFirst(): [s4]
42 After offer(): [s4, s5]
43 After add(): [s4, s5, s6]
44 After addLast(): [s4, s5, s6, s7]
45 ls.removeLast(): s7
46 *///:~

说完了List,我们一定会想到数据结构中非常重要的两种,队列和栈,在Java中这两种数据结构我们应该怎么实现呢?这就要用到我们刚介绍的LinkedList

栈和队列

栈:

“栈”通常指后进先出(LIFO)的容器,在博文刚开始的图中,我们肯定会发现Java容器类库的结构图中已经包含了栈这个结构,但是基于在Java1.0中设计者的失误导致Stack在新版本的Java中是不推荐使用(这里原因不具体废话了,反正就是不用它便是),然而有了LinkedList,我们完全可以自己很快的写一个,因为说到底栈无非就是操作受限的链表(它只允许在链表的一端进行读写操作)。

代码:

 1 import java.util.LinkedList;
 2 
 3 public class Stack<T> {
 4     private LinkedList<T> storage = new LinkedList<T>();
 5 
 6     public void push(T v) {
 7         storage.addFirst(v);
 8     }
 9 
10     public T peek() {
11         return storage.getFirst();
12     }
13 
14     public T pop() {
15         return storage.removeFirst();
16     }
17 
18     public boolean empty() {
19         return storage.isEmpty();
20     }
21 
22     public String toString() {
23         return storage.toString();
24     }
25 } // /:~ 

这里我们将LinkedList用组合的方式封装在我们的Stack类中,切记这里不能使用继承,因为如果我们的Stack类继承自LinkedList,那么从外部我们就可以获得所有LinkedList的public接口,那么栈就没意义了(其实Java1.0中的Stack的设计就犯了这个错误)

队列:

“队列”是一个典型的先进先出(FIFO)的容器,并且在【Java心得总结五】Java容器上——容器初探博文的图中我们可以看到LinkedList除了实现了List接口还实现了Queue接口,这也就是为什么我们在上面介绍LinkedList时会有那么多功能重复但是名字不同的方法的原因了。

代码:

 1 import java.util.*;
 2 
 3 public class QueueDemo {
 4     public static void printQ(Queue queue) {
 5         while (queue.peek() != null)
 6             System.out.print(queue.remove() + " ");
 7         System.out.println();
 8     }
 9 
10     public static void main(String[] args) {
11         Queue<Integer> queue = new LinkedList<Integer>();
12         Random rand = new Random(47);
13         for (int i = 0; i < 10; i++)
14             queue.offer(rand.nextInt(i + 10));
15         printQ(queue);
16         Queue<Character> qc = new LinkedList<Character>();
17         for (char c : "Brontosaurus".toCharArray())
18             qc.offer(c);
19         printQ(qc);
20     }
21 } /*
22  * Output: 8 1 1 1 5 14 3 1 0 1 B r o n t o s a u r u s
23  */// :~ 

其实从上面我们可以看出我们利用Queue来持有LinkedList对象时,Queue窄化了LinkedList的方法访问权限,以使得有恰当的方法才可以使用。(这很合理,因为同栈一样,队列说到底也是操作受限的链表,它只允许在一端写入另一端读)

List的遍历

像数组一样,我们对容器列表经常做得操作就是遍历,当然了我们可以向遍历数组一样用一个迭代变量进行叠加,然后利用get()方法来取出对应索引位置的元素来达到遍历的目的。但是还有一个更好的方法就是利用Iterator接口(参见【Java心得总结五】Java容器上——容器初探)

二、Set接口

Set最最重要的特征就是不保存重复元素。从博文开始的图中我们可以看出Set接口主要有两种具体的实现:HashSet和TreeSet,而在HashSet的基础上还实现了一个LinkedHashSet。

  • HashSet:拥有最快的查询速度,存入HashSet的元素必须定义hashCode()方法
  • TreeSet:保持元素处于排序状态,底层为树结构。使用它可以从Set中提取有序的序列。元素必须实现Comparable接口
  • LinkedHashSet:以插入顺序保持元素,用迭代器进行遍历时会按照插入时的顺序显示,但也必须定义hashCode()方法

Set具有与Collection完全一样的接口,因此没有任何额外的功能,不像前面有两个不同的List。实际上Set就是Collection,只是行为不同。(这是继承与多态思想的典型应用:表现不同的行为。)Set是基于对象的值来确定对象的归属性的。

代码示例:

 1 import java.util.*;
 2 
 3 class SetType {
 4     int i;
 5 
 6     public SetType(int n) {
 7         i = n;
 8     }
 9 
10     public boolean equals(Object o) {
11         return o instanceof SetType && (i == ((SetType) o).i);
12     }
13 
14     public String toString() {
15         return Integer.toString(i);
16     }
17 }
18 
19 class HashType extends SetType {
20     public HashType(int n) {
21         super(n);
22     }
23 
24     public int hashCode() {
25         return i;
26     }
27 }
28 
29 class TreeType extends SetType implements Comparable<TreeType> {
30     public TreeType(int n) {
31         super(n);
32     }
33 
34     public int compareTo(TreeType arg) {
35         return (arg.i < i ? -1 : (arg.i == i ? 0 : 1));
36     }
37 }
38 
39 public class TypesForSets {
40     static <T> Set<T> fill(Set<T> set, Class<T> type) {
41         try {
42             for (int i = 0; i < 10; i++)
43                 set.add(type.getConstructor(int.class).newInstance(i));
44         }
45         catch (Exception e) {
46             throw new RuntimeException(e);
47         }
48         return set;
49     }
50 
51     static <T> void test(Set<T> set, Class<T> type) {
52         fill(set, type);
53         fill(set, type); // Try to add duplicates
54         fill(set, type);
55         System.out.println(set);
56     }
57 
58     public static void main(String[] args) {
59         test(new HashSet<HashType>(), HashType.class);
60         test(new LinkedHashSet<HashType>(), HashType.class);
61         test(new TreeSet<TreeType>(), TreeType.class);
62         // Things that don’t work:
63         test(new HashSet<SetType>(), SetType.class);
64         test(new HashSet<TreeType>(), TreeType.class);
65         test(new LinkedHashSet<SetType>(), SetType.class);
66         test(new LinkedHashSet<TreeType>(), TreeType.class);
67         try {
68             test(new TreeSet<SetType>(), SetType.class);
69         }
70         catch (Exception e) {
71             System.out.println(e.getMessage());
72         }
73         try {
74             test(new TreeSet<HashType>(), HashType.class);
75         }
76         catch (Exception e) {
77             System.out.println(e.getMessage());
78         }
79     }
80 }
81 /*
82 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
83 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
84 [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
85 [8, 9, 2, 1, 6, 7, 1, 5, 8, 7, 8, 0, 5, 5, 2, 0, 1, 6, 4, 7, 3, 2, 9, 0, 6, 9, 4, 4, 3, 3]
86 [0, 9, 4, 0, 8, 5, 6, 7, 7, 9, 8, 6, 1, 4, 1, 3, 3, 7, 6, 2, 0, 4, 3, 5, 9, 2, 8, 5, 1, 2]
87 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
88 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
89 java.lang.ClassCastException: SetType cannot be cast to java.lang.Comparable
90 java.lang.ClassCastException: HashType cannot be cast to java.lang.Comparable
91 *///:~

这里不得不提的是hashCode()和Comparable接口这会在下篇博文中进行详细解释(【Java心得总结七】Java容器下——Map)

代码中SetType作为基类,而HashType和TreeType分别对HashSet和TreeSet做了展示(二者分别实现了hashCode()和Comparable接口)

 

总结:

这篇博文对Java容器类库中的Collection部分做了详细的阐述,在Set这里还留了个尾巴即hashCode()和Comparable接口的问题(要不篇幅太长了),将在下篇博文进行总结。

 

 

转载于:https://www.cnblogs.com/xlturing/p/3790064.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/359804.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php 文章读取_php实现获取文章内容第一张图片的方法

本文实例讲述了php实现获取文章内容第一张图片的方法。分享给大家供大家参考。具体分析如下&#xff1a;采用php获取文章内容的第一张图片方法非常的简单&#xff0c;我们最常用的是使用正则了&#xff0c;感兴趣的朋友可以参考一下下面这段代码。以下是关于选取文章中第一张图…

昨天帮同学的学校写了首校歌

转载于:https://www.cnblogs.com/del/p/3792526.html

php做一个微信退款,PHP实现微信申请退款流程实例代码

前面讲了怎么实现微信支付&#xff0c;详见博文&#xff1a;php实现微信支付(jsapi支付)流程 和ThinkPHP中实现微信支付(jsapi支付)流程。由于业务需求&#xff0c;还需要有微信退款&#xff0c;经过研究和摸索&#xff0c;也终于搞定了。前期准备&#xff1a;当然是搞定了微信…

gwt格式_使用Spring Security保护GWT应用程序的安全

gwt格式在本教程中&#xff0c;我们将看到如何将GWT与Spring的安全模块&#xff08;即Spring Security&#xff09;集成。 我们将看到如何保护GWT入口点&#xff0c;如何检索用户的凭据以及如何记录各种身份验证事件。 此外&#xff0c;我们将实现自定义身份验证提供程序&#…

K-Means算法Demo

简介&#xff1a;本Demo是参照这个网站上的Demo自己用Java实现的。将Java打包为Jar&#xff0c;再将Jar转为exe&#xff0c;源代码及程序Demo下载请点我。 K-Means算法简介 我尽量用通俗易懂但不规范的语言来描述K-Means算法。 K-Means算法是数据挖掘十大算法之一&#xff0c;是…

php 时间周期,php 的生命周期

1、PHP的运行模式&#xff1a;PHP两种运行模式是WEB模式、CLI模式。无论哪种模式&#xff0c;PHP工作原理都是一样的&#xff0c;作为一种SAPI运行。1、当我们在终端敲入php这个命令的时候&#xff0c;它使用的是CLI。它就像一个web服务器一样来支持php完成这个请求&#xff0c…

struts2与struts1整合,java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory

原因&#xff1a;我往项目的WEB-INF/lib中导入了struts2基本的包&#xff0c;还有struts1的core包&#xff0c;以及struts2-strut1-plugin的包&#xff0c;但是没有导入commons-loggin-1.3.1这个包&#xff0c;如下图 我打开commons-loggin-1.3.1这个包看了一下&#xff0c;果然…

debian 查看php版本,Debian 下轻松实现 PHP 多版本共存

PHP7 的发布废弃了部分特性&#xff0c;一些程序或者插件当前不能很好的运行在 PHP7 上&#xff0c;因此如果服务器上能同时运行多个 PHP 的版本&#xff0c;就可以很好的解决过渡期的兼容性问题。在前面两篇文章中&#xff0c;我们介绍了如何在 Debian Stretch 中安装使用 PHP…

apache lucene_全文搜索Apache Lucene简介

apache lucene在本教程中&#xff0c;我想谈谈Apache Lucene 。 Lucene是一个开源项目&#xff0c;提供基于Java的索引和搜索技术。 使用其API&#xff0c;很容易实现全文搜索 。 我将处理Lucene Java版本 &#xff0c;但请记住&#xff0c;还有一个名为Lucene.NET的.NET端口&a…

经典ICP算法的问题

最近可能要用三维点云实现一个三维场景重建的功能&#xff0c;从经典的ICP算法开始&#xff0c;啃了一些文档&#xff0c;对其原理也是一知半解。 迭代最近点算法综述 大致参考了这份文档之后&#xff0c;照流程用MATLAB实现了一个简单的ICP算法&#xff0c;首先是发现这份文档…

iOS执行时工具-cycript

cycript是大神saurik开发的一个很强大的工具&#xff0c;能够让开发人员在命令行下和应用交互&#xff0c;在执行时查看和改动应用。它确实能够帮助你破解一些应用&#xff0c;但我认为这个工具主要还是用来学习其它应用的设计&#xff08;主要是UI的设计及实现&#xff09;。 …

java是如何实现原语的_Java中的低GC:使用原语而不是包装器

java是如何实现原语的总览 有两个很好的理由在可能的地方使用原语而不是包装器。 明晰。 通过使用原语&#xff0c;您可以清楚地知道null值是不合适的。 性能。 使用原语通常更快。 清晰度通常比性能更重要&#xff0c;并且是使用它们的最佳理由。 但是&#xff0c;本文讨论…

BrnShop开源网上商城第二讲:ASP.NET MVC框架

BrnShop开源网上商城第二讲&#xff1a;ASP.NET MVC框架 原文:BrnShop开源网上商城第二讲&#xff1a;ASP.NET MVC框架在团队设计BrnShop的web项目之初&#xff0c;我们碰到了两个问题&#xff0c;第一个是数据的复用和传递&#xff0c;第二个是大mvc框架和小mvc框架的选择。下…

tomcat不停机部署_Tomcat中的零停机部署(和回滚); 演练和清单

tomcat不停机部署亲爱的大家&#xff0c; 如果您认为Tomcat不能再进步&#xff0c;那您就错了。 Tomcat 7引入了所谓的并行部署 。 这是由SpringSource / VMWare贡献的。 简而言之&#xff0c;并行部署是指能够并行部署一个以上版本的Web应用程序&#xff0c;从而使所有版本都…

matlab三维选取二维,基于Matlab绘制二维和三维图形以及其他图形控制函数的使用方法...

Matlab绘图强大的绘图功能是Matlab的特点之一&#xff0c;Matlab提供了一系列的绘图函数&#xff0c;用户不需要过多的考虑绘图的细节&#xff0c;只需要给出一些基本参数就能得到所需图形&#xff0c;这类函数称为高层绘图函数。此外&#xff0c;Matlab还提供了直接对图形句柄…

Console命令详解,让调试js代码变得更简单

刚刚在浏览关于js方面的博客时发现这个方法挺好玩的&#xff0c;自己爽了一把。 1 <script> 2 console.time(/X(.)X/ test); 3 "XX".match(/X(.)X/); 4 console.timeEnd(/X(.)X/ test); 5 </script> 然后恶补了一下关于Firebug控制台的知识。熟练地使用…

PHP求体重成绩函数,PHP数组

数组提出一个问题&#xff1a;一个养鸡场有6只鸡&#xff0c;他们的体重分别为3kg&#xff0c;5kg&#xff0c;1k个&#xff0c;3.4kg&#xff0c;2kg&#xff0c;6.kg请问这六只鸡的总体重是多少平均体重是多少请你用现在掌握的技术编一个程序现在我们使用现有的技术来解决问题…

k8s secret使用_Java Secret:使用枚举构建状态机

k8s secret使用总览 Java中的枚举比许多其他语言更强大&#xff0c;可以导致令人惊讶的用途。 在本文中&#xff0c;我概述了Java 枚举的一些单独功能&#xff0c;并将它们放在一起形成一个状态机。 单例和实用程序类的枚举 您可以非常简单地将枚举用作Singleton或Utility。…

mydumper备份原理和使用方法

mydumper介绍 MySQL自身的mysqldump工具支持单线程工作&#xff0c;依次一个个导出多个表&#xff0c;没有一个并行的机&#xff0c;这就使得它无法迅速的备份数据。 mydumper作为一个实用工具&#xff0c;能够良好支持多线程工作&#xff0c;可以并行的多线程的从表中读入数据…

matlab pca可视化,利用Matlab实现PCA demo展示

input_data rand(1000,3);%随机生成1000个样本&#xff0c;每个样本有x,y,z三个属性 figure(1);%控制画图的窗口为1hold off;%使当前轴和图形不再具备被刷新的性质&#xff0c;关闭在此基础上再画图plot3(input_data(:,1), input_data(:,2), input_data(:,3), ‘ro‘);%% Func…