当前位置: 首页 > news >正文

Java笔记026-集合/数组、Collection接口、ArrayList、Vector、LinkedList

集合

集合的理解和好处

保存多个数据使用的是数组,分析数组的弊端

数组

1、长度开始必须指定,而且一旦指定,不能更改

2、保存的必须为同一类型的元素

3、使用数组进行增加/删除元素的示意代码-比较麻烦

Person数组扩容示意代码

Person[] pers = new Person[1];//大小是1
pers[0] = new Person();
//增加新的Person对象
Person[] pers2 = new Person[pers.length + 1];//创建新数组
for(){}//拷贝pers数组的元素到pers2
pers2[pers2.length - 1] = new Person();//添加新的对象

集合

1、可以动态保存任意多个对象,使用比较方便!

2、提供了一系列方便的操作对象的方法:add、remove、set、get等

3、使用集合添加,删除新元素的示意代码-简洁

集合的框架体系

Java的集合类很多,主要分为两大类,如图:

package com14.collection_;import java.util.ArrayList;
import java.util.HashMap;/*** @author 甲柒* @version 1.0* @title Collection_* @package com14.collection_* @time 2023/1/13 17:53*/
public class Collection_ {@SuppressWarnings({"all"})public static void main(String[] args) {//解读//1.集合主要是两组(单列集合,双列集合)//2.Collection接口有两个重要的子接口 List Set,他们的实现子类都是单列集合//3.Map接口的实现子类是双列集合,存放的 K-V
//        Collection
//        MapArrayList arrayList = new ArrayList();arrayList.add("jack");arrayList.add("tom");HashMap hashMap = new HashMap();hashMap.put("NO1", "北京");hashMap.put("NO2", "上海");}
}

Collection接口和常用方法

Collection接口实现类的特点

public interface Collection<E> extends lterable<E>

1、Collection实现子类可以存放多个元素,每个元素可以是Object

2、有些Collection的实现类,可以存放重复的元素,有些不可以

3、有些Collection的实现类,有些是有序的(List),有些不是有序(Set)

4、Collection接口没有直接的实现子类,是通过它的子接口Set和List来实现的

Collection接口和常用方法

1、add //添加单个元素

2、remove //删除指定元素

3、contains //查找元素是否存在

4、size //获取元素个数

5、isEmpty //判断是否为空

6、clear //清空

7、addAll //添加多个元素

8、containsAll //查找多个元素是否都存在

9、removeAll //删除多个元素

10、说明:以ArrayList实现类来演示

package com14.collection_;import java.util.ArrayList;/*** @author 甲柒* @version 1.0* @title CollectionMethod* @package com14.collection_* @time 2023/1/13 18:42*/
public class CollectionMethod {@SuppressWarnings({"all"})public static void main(String[] args) {ArrayList arrayList = new ArrayList();//1、add //添加单个元素arrayList.add("jack");arrayList.add(10);arrayList.add(true);System.out.println("arrayList=" + arrayList);//2、remove //删除指定元素
//        arrayList.remove(0);//删除第一个元素arrayList.remove(true);//指定删除某个元素System.out.println("arrayList=" + arrayList);//3、contains //查找元素是否存在System.out.println(arrayList.contains("jack"));//true//4、size //获取元素个数System.out.println(arrayList.size());//2//5、isEmpty //判断是否为空System.out.println(arrayList.isEmpty());//false//6、clear //清空arrayList.clear();System.out.println("arrayList=" + arrayList);//7、addAll //添加多个元素ArrayList arrayList1 = new ArrayList();arrayList1.add("西游记");arrayList1.add("三国演义");arrayList.addAll(arrayList1);System.out.println("arrayList=" + arrayList);//8、containsAll //查找多个元素是否都存在System.out.println(arrayList.containsAll(arrayList1));//true//9、removeAll //删除多个元素arrayList.add("鬼吹灯");arrayList.removeAll(arrayList1);System.out.println("arrayList=" + arrayList);//鬼吹灯//10、说明:以ArrayList实现类来演示}
}

Collection接口遍历元素方式1-使用Iterator(迭代器)

基本介绍

1、Iterator对象称为迭代器,主要用于遍历Collection集合中的元素。

2、所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了lterator接口的对象,即可以返回一个迭代器。

3、Iterator的结构。[图:]

4、Iterator仅用于遍历集合,Iterator本身并不存放对象。

迭代器的执行原理

Iterator iterator = coll.iterator();//得到一个集合的迭代器

//hasNext():判断是否还有下一个元素

while(iterator.hasNext()){

//next()作用:1.指针下移2.将下移以后集合位置上的元素返回

System.out.println(iterator.next());

}

Iterator接口的方法

注意:在调用iterator.next()方法之前必须要调用iterator.hasNext()进行检测。若不调用,且下一条记录无效,直接调用itterator.next()会抛出NoSuchElementException异常

package com14.collection_;import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;/*** @author 甲柒* @version 1.0* @title CollectionIterator* @package com14.collection_* @time 2023/1/28 17:44*/
public class CollectionIterator {@SuppressWarnings({"all"})public static void main(String[] args) {Collection collection = new ArrayList();collection.add(new Book("三国演义", "罗贯中", 49.9));collection.add(new Book("三体", "刘慈欣", 139.9));collection.add(new Book("流浪地球", "刘慈欣", 69.9));//        System.out.println("collection=" + collection);//现在希望能够遍历collection集合//1.先得到collection对应的迭代器Iterator iterator = collection.iterator();//2.使用while循环遍历
//        while (iterator.hasNext()) {//判断是否还有数据
//            //返回下一个元素,类型是Objext
//            Object obj = iterator.next();
//            System.out.println("obj=" + obj);
//        }//快捷键 快速生成while => itit//显示所有快捷键的快捷键 ctrl + jwhile (iterator.hasNext()) {Object next = iterator.next();System.out.println(next);}//3.当退出while循环后,这时iterator迭代器,指向最后的元素
//        iterator.next();//NoSuchElementException//4.如果希望再次遍历,需要重置迭代器iterator = collection.iterator();System.out.println("=====第2次遍历=====");while (iterator.hasNext()) {Object next = iterator.next();System.out.println(next);}}
}class Book {private String name;private String author;private double price;public Book(String name, String author, double price) {this.name = name;this.author = author;this.price = price;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getAuthor() {return author;}public void setAuthor(String author) {this.author = author;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}@Overridepublic String toString() {return "Book{" +"name='" + name + '\'' +", author='" + author + '\'' +", price=" + price +'}';}
}

Collection接口遍历对象方式2-for循环增强

增强for循环,可以代替iterator迭代器,特点:增强for就是简化版的iterator,本质一样 。只能用于遍历集合或数组。

基本语法

for(元素类型 元素名:集合名或数组名){访问元素
}

案例演示

package com14.collection_;import java.util.ArrayList;
import java.util.Collection;/*** @author 甲柒* @version 1.0* @title CollectionFor* @package com14.collection_* @time 2023/1/28 18:11*/
public class CollectionFor {@SuppressWarnings({"all"})public static void main(String[] args) {Collection collection = new ArrayList();collection.add(new Book("三国演义", "罗贯中", 49.9));collection.add(new Book("三体", "刘慈欣", 139.9));collection.add(new Book("流浪地球", "刘慈欣", 69.9));//解读//1.使用增强for,在Collection集合//2.增强for,底层仍然是迭代器//3.增强for,可以理解成就是简化版的 迭代器遍历for (Object book :collection) {System.out.println(book);}//增强for,也可以直接在数组使用
//        int[] nums = {1, 8, 10, 99};
//        for (int i : nums) {
//            System.out.println("i=" + i);
//        }}
}

练习题

请编写程序

1、创建3个 Dog {name, age} 对象,放入到 ArrayList中,赋给List 引用

2、用迭代器和增强for循环两种方式来遍历

3、重写Dog的toString方法,输出name和age

package com14.collection_;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @author 甲柒* @version 1.0* @title CollectionExercise* @package com14.collection_* @time 2023/1/28 18:21*/
public class CollectionExercise {@SuppressWarnings({"all"})public static void main(String[] args) {List list = new ArrayList();list.add(new Dog("大黄", 5));list.add(new Dog("大白", 10));list.add(new Dog("大黑", 3));//先使用for增强for (Object dog : list) {System.out.println("dog=" + dog);}//使用迭代器System.out.println("=======使用迭代器=======");Iterator iterator = list.iterator();while (iterator.hasNext()) {Object dog = iterator.next();System.out.println("dog=" + dog);}}
}/*** 1、创建3个 Dog {name, age} 对象,放入到 ArrayList中,赋给List 引用* 2、用迭代器和增强for循环两种方式来遍历* 3、重写Dog的toString方法,输出name和age*/
class Dog {private String name;private int age;public Dog(String name, int age) {this.name = name;this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}@Overridepublic String toString() {return "Dog{" +"name='" + name + '\'' +", age=" + age +'}';}
}

List接口和常用方法

List接口基本介绍

List接口是Collection接口的子接口

  1. List集合类中的元素有序(即添加顺序和取出顺序一致)、且可重复

  1. List集合中的每个元素都有其对应的顺序索引,即支持索引

  1. List容器中的元素都对应一个整数类型的序号记载其在容器中的位置,可以根据序号存取容器中的元素

  1. JDK API中List接口的实现类有:

package com14.list_;import java.util.ArrayList;
import java.util.List;/*** @author 甲柒* @version 1.0* @title List_* @package com14.list_* @time 2023/2/20 9:34*/
public class List_ {public static void main(String[] args) {//1.List集合类中元素有序(即添加顺序和取出顺序一致)、且可重复List list = new ArrayList();list.add("tom");list.add("jack");list.add("marry");list.add("lsp");list.add("lsp");System.out.println("list" + list);//2.List集合中的每个元素都有其对应的顺序索引,即支持索引System.out.println(list.get(2));}
}

List接口的常用方法

List集合里添加了一些根据索引来操作集合元素的方法

  1. void add(int index, Object ele):在index位置插入ele元素

  1. boolean addAll(int index, Collection eles):从index位置开始将eles中的所有元素添加进来

  1. Object get(int index):获取指定index位置的元素

  1. int indexOf(Object obj):返回obj在集合中首次出现的位置

  1. int lastIndexOf(Object obj):返回obj在当前集合中末次出现的位置

  1. Object remove(int index):移除指定index位置的元素,并返回此元素

  1. Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换

  1. List subList(int fromIndex, int toIndex):返回从fromIndex到toIndex位置的子集合

package com14.list_;import java.util.ArrayList;
import java.util.List;/*** @author 甲柒* @version 1.0* @title ListMethod* @package com14.list_* @time 2023/2/20 10:36*/
public class ListMethod {@SuppressWarnings({"all"})public static void main(String[] args) {List list = new ArrayList();list.add("渣渣辉");list.add("唐玄奘");
//        void add(int index, Object ele):在index位置插入ele元素//在index = 1的位置插入一个对象list.add(1, "甲柒");System.out.println("list=" + list);
//        boolean addAll(int index, Collection eles):从index位置开始将eles中的所有元素添加进来List list2 = new ArrayList();list2.add("jack");list2.add("tom");list.addAll(1, list2);System.out.println("list=" + list);
//        Object get(int index):获取指定index位置的元素System.out.println(list.get(2));
//        int indexOf(Object obj):返回obj在集合中首次出现的位置System.out.println(list.indexOf("tom"));
//        int lastIndexOf(Object obj):返回obj在当前集合中末次出现的位置list.add("甲柒");System.out.println("list=" + list);System.out.println(list.lastIndexOf("甲柒"));
//        Object remove(int index):移除指定index位置的元素,并返回此元素list.remove(0);System.out.println("list=" + list);
//        Object set(int index, Object ele):设置指定index位置的元素为ele,相当于是替换list.set(1, "沈腾");System.out.println("list=" + list);
//        List subList(int fromIndex, int toIndex):返回从fromIndex到toIndex位置的子集合List list1 = list.subList(0, 2);System.out.println("list1=" + list1);}
}

List接口练习题1

添加10个以上的元素(比如String "hello"),在2号位插入一个元素"甲柒",获得第5个元素,删除第6个元素,修改第7个元素,在使用迭代器遍历集合,要求:使用List的实现类ArrayList完成。

package com14.list_;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @author 甲柒* @version 1.0* @title ListExercise* @package com14.list_* @time 2023/2/20 18:55*/
public class ListExercise {//    添加10个以上的元素(比如String "hello"),
//    在2号位插入一个元素"甲柒",获得第5个元素,
//    删除第6个元素,修改第7个元素,在使用迭代器遍历集合,
//    要求:使用List的实现类ArrayList完成。@SuppressWarnings({"all"})public static void main(String[] args) {List list = new ArrayList();for (int i = 0; i < 12; i++) {list.add("hello" + i);}System.out.println("List=" + list);
//        在2号位插入一个元素"甲柒"list.add(1, "甲柒");System.out.println("List=" + list);
//        获得第5个元素,System.out.println("第五个元素=" + list.get(4));
//        删除第6个元素list.remove(5);System.out.println("List=" + list);
//        修改第7个元素list.set(6, "java");System.out.println("List=" + list);
//        在使用迭代器遍历集合Iterator iterator = list.iterator();while (iterator.hasNext()) {Object next = iterator.next();System.out.println("next=" + next);}}
}

List三种遍历方式[ArrayList、Linked、Vector]

package com14.list_;import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;/*** @author 甲柒* @version 1.0* @title ListFor* @package com14.list_* @time 2023/2/20 19:12*/
public class ListFor {@SuppressWarnings({"all"})public static void main(String[] args) {
//        List 接口的实现子类  LinkedList
//        List list = new ArrayList();
//        List list = new Vector();List list = new LinkedList();list.add("蟹老板");list.add("章鱼哥");list.add("海绵宝宝");list.add("派大星");//遍历//1.迭代器System.out.println("==========迭代器==========");Iterator iterator = list.iterator();while (iterator.hasNext()) {Object next = iterator.next();System.out.println(next);}System.out.println("==========增强for==========");//2.增强forfor (Object o : list) {System.out.println(o);}System.out.println("==========普通for==========");//3.普通forfor (int i = 0; i < list.size(); i++) {System.out.println(list.get(i));}}
}

List接口练习题2

使用List的实现类添加三本书,并遍历,打印效果如下

要求:

  1. 按价格排序,从低到高(使用冒泡排序)

  1. 使用ArrayList、LinkedList、Vector三种集合实现

package com14.list_;import java.util.LinkedList;
import java.util.List;/*** @author 甲柒* @version 1.0* @title ListExercise02* @package com14.list_* @time 2023/2/20 19:30*/
@SuppressWarnings({"all"})
public class ListExercise02 {public static void main(String[] args) {
//        List list = new ArrayList();List list = new LinkedList();
//        List list = new Vector();list.add(new Book("红楼梦", 39, "曹雪芹"));list.add(new Book("西游记", 100, "吴承恩"));list.add(new Book("水浒传", 9.9, "施耐庵"));list.add(new Book("三国演义", 88, "罗贯中"));
//        list.add(new Book("红楼梦","39","曹雪芹"));//遍历for (Object o : list) {System.out.println(o);}//冒泡排序sort(list);System.out.println("===排序后===");//遍历for (Object o : list) {System.out.println(o);}}//静态方法public static void sort(List list) {int listSize = list.size();for (int i = 0; i < listSize - 1; i++) {for (int j = 0; j < listSize - 1 - i; j++) {//取出对象BookBook book1 = (Book) list.get(j);Book book2 = (Book) list.get(j + 1);if (book1.getPrice() > book2.getPrice()) {list.set(j, book2);list.set(j + 1, book1);}}}}
}

ArryList的注意事项

  1. permits all elements,including null,ArrayList可以加入null,并且多个

  1. ArrayList是由数组来实现数据存储的

  1. ArrayList基本等同于Vector,除了ArrayList是线程不安全(执行效率高),在多线程情况下,不建议使用ArrayList

package com14.list_;import java.util.ArrayList;/*** @author 甲柒* @version 1.0* @title ArrayListDetail* @package com14.list_* @time 2023/2/21 19:46*/
@SuppressWarnings({"all"})
public class ArrayListDetail {public static void main(String[] args) {//ArrayList是线程不安全的,源码中没有synchronized/*public boolean add(E e) {ensureCapacityInternal(size + 1);  // Increments modCount!!elementData[size++] = e;return true;}*/ArrayList arrayList = new ArrayList();arrayList.add(null);arrayList.add("jack");arrayList.add(null);System.out.println(arrayList);}
}

ArrayList底层结构和源码分析

ArrayList的底层操作机制源码分析

1、ArrayList中维护了一个Object类型的数组elementData

transient Object[] elementData;//transient表示瞬间,短暂的,表示该属性不会被序列号

2、当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需再次扩容,则扩容elementData为1.5倍

3、如果使用的是指定大小的构造器,则初始elementData容量为指定大小,如需要扩容,则直接扩容elementData为1.5倍

package com14.list_;import java.util.ArrayList;/*** @author 甲柒* @version 1.0* @title ArrayListSource* @package com14.list_* @time 2023/2/21 21:41*/
@SuppressWarnings({"all"})
public class ArrayListSource {public static void main(String[] args) {//解读//使用无参构造器创建ArrayList对象ArrayList list = new ArrayList();//ArrayList list = new ArrayList(8);//使用for给list集合添加1-10数据for (int i = 1; i <= 10; i++) {list.add(i);}//使用for给list集合添加11-15数据for (int i = 11; i <= 15; i++) {list.add(i);}list.add(100);list.add(200);list.add(null);}
}

Vector底层结构和源码剖析

Vector的基本介绍

1、Vector类的定义说明

2、Vector底层也是一个对象数组,protected Object[] elementData

3、Vector是线程同步的,即线程安全,Vector类的操作方法带有synchronized

4、在开发中,需要线程同步安全时,考虑使用Vector

Vector底层结构和ArrayList的比较

Vector和ArrayList的比较

LinkedList底层结构

LiskedList的全面说明

  1. LiskedList底层实现了双向链表和双端队列特点

  1. 可以添加任意元素(元素可以重复),包括null

  1. 线程不安全,没有实现同步

LiskedList的底层操作机制

  1. LinkedList底层维护了一个双向链表

  1. LinkedList中维护了两个属性first和last分别指向首节点和尾节点

  1. 每个节点(Node对象),里又维护了prev、next、item三个属性,其中通过prev指向前一个节点,通过next指向后一个节点,最终实现双链表

  1. 所以LinkedList的元素的添加和删除,不是通过数组完成的,相对来说效率较高

  1. 模拟一个简单的双链表

package com14.list_;/*** @author 甲柒* @version 1.0* @title LinkedList* @package com14.list_* @time 2023/2/21 22:55*/
public class LinkedList {public static void main(String[] args) {//模拟一个简单的双向链表Node jack = new Node("jack");Node tom = new Node("tom");Node jerry = new Node("jerry");//连接三个结点,形成双向链表//jack -> tom -> jerryjack.next = tom;tom.next = jerry;//jerry -> tom -> jackjerry.pre = tom;tom.pre = jack;Node first = jack;//让first引用指向jack,就是双向链表的头结点Node last = jerry;//让last引用指向hsp,就是双向链表的尾结点//演示,从头到尾进行遍历System.out.println("===从头到尾进行遍历===");while (true) {if (first == null) {break;}//输出first 信息System.out.println(first);first = first.next;}//演示,从尾到头的遍历System.out.println("====从尾到头的遍历====");while (true) {if (last == null) {break;}//输出last 信息System.out.println(last);last = last.pre;}//演示链表的添加对象/数据,是多么的方便//要求,是在 tom --------- 老韩直接,插入一个对象 smith//1. 先创建一个 Node 结点,name 就是 smithNode smith = new Node("smith");//下面就把 smith 加入到双向链表了smith.next = jerry;smith.pre = tom;jerry.pre = smith;tom.next = smith;//让first 再次指向jackfirst = jack;//让first引用指向jack,就是双向链表的头结点System.out.println("===从头到尾进行遍历===");while (true) {if (first == null) {break;}//输出first 信息System.out.println(first);first = first.next;}last = jerry; //让last 重新指向最后一个结点//演示,从尾到头的遍历System.out.println("====从尾到头的遍历====");while (true) {if (last == null) {break;}//输出last 信息System.out.println(last);last = last.pre;}}
}//定义一个Node 类,Node 对象 表示双向链表的一个结点
class Node {public Object item; //真正存放数据public Node next; //指向后一个结点public Node pre; //指向前一个结点public Node(Object name) {this.item = name;}public String toString() {return "Node name=" + item;}
}

LinkedList的增删改查案例

package com14.list_;import java.util.Iterator;
import java.util.LinkedList;/*** @author 甲柒* @version 1.0* @title LInkedListCRUD* @package com14.list_* @time 2023/2/22 20:22*/
@SuppressWarnings({"all"})
public class LInkedListCRUD {public static void main(String[] args) {LinkedList linkedList = new LinkedList();linkedList.add(1);linkedList.add(2);linkedList.add(3);System.out.println("linkedList=" + linkedList);//演示一个删除结点的linkedList.remove(); // 这里默认删除的是第一个结点//linkedList.remove(2);System.out.println("linkedList=" + linkedList);//修改某个结点对象linkedList.set(1, 999);System.out.println("linkedList=" + linkedList);//得到某个结点对象//get(1) 是得到双向链表的第二个对象Object o = linkedList.get(1);System.out.println(o);//999//因为LinkedList 是 实现了List接口, 遍历方式System.out.println("===LinkedList遍历迭代器====");Iterator iterator = linkedList.iterator();while (iterator.hasNext()) {Object next = iterator.next();System.out.println("next=" + next);}System.out.println("===LinkedList遍历增强for====");for (Object o1 : linkedList) {System.out.println("o1=" + o1);}System.out.println("===LinkedList遍历普通for====");for (int i = 0; i < linkedList.size(); i++) {System.out.println(linkedList.get(i));}//源码阅读./* 1. LinkedList linkedList = new LinkedList();public LinkedList() {}2. 这时 linkedList 的属性 first = null  last = null3. 执行 添加public boolean add(E e) {linkLast(e);return true;}4.将新的结点,加入到双向链表的最后void linkLast(E e) {final Node<E> l = last;final Node<E> newNode = new Node<>(l, e, null);last = newNode;if (l == null)first = newNode;elsel.next = newNode;size++;modCount++;}*//*读源码 linkedList.remove(); // 这里默认删除的是第一个结点1. 执行 removeFirstpublic E remove() {return removeFirst();}2. 执行public E removeFirst() {final Node<E> f = first;if (f == null)throw new NoSuchElementException();return unlinkFirst(f);}3. 执行 unlinkFirst, 将 f 指向的双向链表的第一个结点拿掉private E unlinkFirst(Node<E> f) {// assert f == first && f != null;final E element = f.item;final Node<E> next = f.next;f.item = null;f.next = null; // help GCfirst = next;if (next == null)last = null;elsenext.prev = null;size--;modCount++;return element;}*/}
}

ArrayList和LinkedList比较

ArrayList和LinkedList比较

如何选择ArrayList和LinkedList:

  1. 如果改查的操作多,选择ArrayList

  1. 如果增删的操作多,选择LinkedList

  1. 一般来说,在程序中,80%~90%都是查询,因此大部分情况下会选择ArrayList

  1. 在一个项目中,根据业务灵活选择,也可以这样,一个模块使用的是ArrayList,另一个模块是LinkedList

相关文章:

Java笔记026-集合/数组、Collection接口、ArrayList、Vector、LinkedList

集合集合的理解和好处保存多个数据使用的是数组&#xff0c;分析数组的弊端数组1、长度开始必须指定&#xff0c;而且一旦指定&#xff0c;不能更改2、保存的必须为同一类型的元素3、使用数组进行增加/删除元素的示意代码-比较麻烦Person数组扩容示意代码Person[] pers new Pe…...

Hive学习——分桶抽样、侧视图与炸裂函数搭配、hive实现WordCount

目录 一、分桶抽样 1.抽取表中10%的数据 2.抽取表中30%的数据 3.取第一行 4.取第10行 5.数据块抽样 6.tablesample详解 二、UDTF——表生成函数 1.explode()——炸裂函数 2.posexpolde()——只能对array进行炸裂 3.inline()——炸裂结构体数组 三、UDTF与侧视图的搭…...

大数据算法

1. TOP K 算法 有10个⽂件&#xff0c;每个⽂件1G&#xff0c;每个⽂件的每⼀⾏存放的都是⽤户的 query&#xff0c;每个⽂件的 query 都可能重复。要求你按照 query 的频度排序。 方法1&#xff1a; 顺序读取10个⽂件&#xff0c;按照 hash(query)%10 的结果将 query 写⼊到…...

非暴力沟通读书笔记

浅读《非暴力沟通》&#xff0c;本书对于沟通的方式总结成了一个方法论&#xff0c;从13个章节去概述非暴力沟通的方法和重点。其中最重要的是非暴力沟通四要素&#xff0c;观察、感受、需要、请求。同时在沟通中注意观察&#xff0c;投入爱&#xff0c;重视倾听的力量&#xf…...

代码随想录【Day21】| 530. 二叉搜索树的最小绝对差、501. 二叉搜索树中的众数、236. 二叉树的最近公共祖先

530. 二叉搜索树的最小绝对差 题目链接 题目描述&#xff1a; 给你一棵所有节点为非负值的二叉搜索树&#xff0c;请你计算树中任意两节点的差的绝对值的最小值。 示例&#xff1a; 提示&#xff1a;树中至少有 2 个节点。 难点&#xff1a; 解答错误&#xff01;仅考虑了…...

注意啦,面试通过后,别忘了教师资格证认定

所有要「教师资格证认定」教程的宝子们看过来面试合格的小伙伴都可以进行认定工作 . 认定时间 查询各省份认定公告&#xff0c;确定认定时间范围。以下是公告汇总网址&#xff08;https://www.jszg.edu.cn/portal/qualification_cert/dynamics?id21691&#xff09; 认定次数 每…...

【LeetCode】No.154. 寻找旋转排序数组中的最小值 II -- Java Version

题目链接&#xff1a;https://leetcode.cn/problems/find-minimum-in-rotated-sorted-array-ii/ 1. 题目介绍&#xff08;154. 寻找旋转排序数组中的最小值 II&#xff09; 已知一个长度为 n 的数组&#xff0c;预先按照升序排列&#xff0c;经由 1 到 n 次 旋转 后&#xff0…...

RestTemplate远程调用

我们现在项目中使用的RPC远程调用技术是Dubbo实际上除了Dubbo技术之外,还有很多远程调用的方法它们有些调用的思想都和Dubbo完全不同Dubbo是SpringCloudAlibaba提供的功能强大的RPC框架但是Dubbo功能也有限制,如果我们想调用的方法不是我们当前项目的组件或功能,甚至想调用的方…...

registerForActivityResult使用

目录 针对 activity 结果注册回调 启动 activity 以获取其结果 在单独的类中接收 activity 结果 测试 创建自定义协定 registerForActivityResult()是startActivityForResult&#xff08;&#xff09;的替代&#xff0c;简化了数据回调的写法 启动另一个 activity&#x…...

工作中,python真的有用吗?

普通上班族学Python有用吗&#xff1f; 那么&#xff0c;我也在这里提出一个问题&#xff1a;Python究竟适不适合办公人士来学习&#xff0c;以及学了之后究竟能不能给我的工作来带质一般的飞跃&#xff1f; 以我的亲身经历为例&#xff0c;我可以很负责的告诉大家&#xff0c…...

固态继电器控制电路

固态继电器控制电路 固态继电器&#xff08;SSR&#xff09;的种类和型号很多&#xff0c;因此其输入控制方法和控制电路也相应众多。固态继电器&#xff08;SSR&#xff09;的共同特点在于驱动电流或驱动电压小&#xff0c;即只需输入一个小信号即可控制SSR的开关。 如果需要…...

数仓、数据湖、湖仓一体、数据网格的探索与研究

第一代&#xff1a;数据仓库 定义 为解决数据库面对数据分析的不足&#xff0c;孕育出新一类产品数据仓库。数据仓库&#xff08;Data Warehouse&#xff09;是一个面向主题的、集成的、相对稳定的、反映历史变化的数据集合&#xff0c;用于支持管理决策和信息的全局共享。 数…...

设计模式系列 - 备忘录模式

介绍&定义 备忘录模式&#xff0c;也叫快照&#xff08;Snapshot&#xff09;模式&#xff0c;英文翻译是 Memento Design Pattern。在 GoF 的《设计模式》一书中&#xff0c;备忘录模式是这么定义的&#xff1a; Captures and externalizes an object’s internal state…...

详细介绍React生命周期和diffing算法

事件处理 1.通过onXxx属性指定事件处理函数(注意大小写) React使用的是自定义(合成)事件, 而不是使用的原生DOM事件 —— 为了更好的兼容性&#xff1b;React中的事件是通过事件委托方式处理的(委托给组件最外层的元素) ——为了的高效。 2.通过event.target得到发生事件的DOM…...

面向对象的特点

1、什么是对象对象的含义是指具体的某一个事物&#xff0c;即在现实生活中能够看得见摸得着的事物。在面向对象程序设计中&#xff0c;对象所指的是计算机系统中的某一个成分。在面向对象程序设计中&#xff0c;对象包含两个含义&#xff0c;其中一个是数据&#xff0c;另外一个…...

智慧校园平台源码 智慧教务 智慧电子班牌系统

系统介绍 智慧校园系统是通过信息化手段,实现对校园内各类资源的有效集成 整合和优化&#xff0c;实现资源的有效配置和充分利用&#xff0c;将校务管理过程的优化协调。为校园提供数字化教学、数字化学习、数字化科研和数字化管理。 致力于为家长和教师提供一个全方位、多层…...

Vue篇.03-组合式API [setup()]

单文件组件(1)<script setup><script setup> 是在单文件组件 (SFC) 中使用组合式 API 的编译时语法糖。当同时使用 SFC 与组合式 API 时该语法是默认推荐启用该语法&#xff0c;需要在 <script> 代码块上添加 setup attribute, 里面的代码会被编译成组件 s…...

QHashIterator-官翻

QHashIterator Class template <typename Key, typename T> class QHashIterator QHashIterator 类为 QHash 和 QMultiHash 提供 Java 风格的常量迭代器。更多内容… 头文件:#include qmake:QT core 所有成员列表&#xff0c;包括继承的成员废弃的成员 公共成员函数…...

[qiankun]-部署后线上问题

[qiankun]-部署后线上问题微服务加载问题-现象1现象描述问题分析解决方案微服务加载问题-现象2现象描述问题分析微服务加载问题-现象3现象描述分析解决方案属于项目打包后&#xff0c;部署到服务器上&#xff0c;所遇到的部分问题 微服务加载问题-现象1 现象描述 项目部署实…...

位图数组 布隆过滤器

文章目录位图数组获取索引获取索引状态设置索引状态布隆过滤器特点大致原理位图数组 一个int类型的整数用4字节,也就是32个bit位来表示&#xff0c;将整数类型的数组转换成位图数组&#xff0c;那么存储长度将变为原来的32倍 arr[0] 表示0-31 arr[1] 表示32-63 //...获取索引…...

多线程Thread常用方法和状态

Thread类 及常见方法 1、常见构造方法 方法说明Thread()创建线程对象Thread(Runnable target)使用 Runnable 对象创建线程对象Thread(String name)创建线程对象&#xff0c;并命名Thread(Runnable target, String name)使用 Runnable 对象创建线程对象&#xff0c;并命名Thre…...

Codeforces Round #836 (Div. 2)

A SSeeeeiinngg DDoouubbllee 题意&#xff1a;告诉你一个字符串。若该串上每一位上的字母都可以出现两次&#xff0c;求回文串 思路&#xff1a;正向再反向输出s即可 #include <bits/stdc.h> #define lowbit(x) x&(-x) #define ios cin.sync_with_stdio(false)…...

Python学习之项目实践: 写一个MP3播放器

下面呢&#xff0c;是一个 Python MP3 播放器&#xff0c;它使用 pygame 模块来实现音乐播放功能&#xff1a; import pygame class MP3Player: """ MP3 播放器类 """ def __init__(self): pygame.mixer.init() def play(self, file_path): &quo…...

RocketMQTemplate 实现消息发送

代码托管于gitee&#xff1a;easy-rocketmq 文章目录一、前置工作二、消费者三、生产者1. 普通消息2. 过滤消息3. 同步消息4. 延时消息5. 批量消息6. 异步消息7. 单向消息8. 顺序消息9. 事务消息概要Demo源码解读一、前置工作 1、导入依赖 <dependency><groupId>…...

教师干货丨这5款微课必备提效神器,我要告诉全世界!

微课是一种短小精悍的视频教学形式&#xff0c;其设计和演示因特别简洁明了而被定义为“小而美”。由于只在几分钟时间内向学生传授所需知识&#xff0c;微课为学习者提供更多的选择机会和时间节约的便利&#xff0c;而这种趋势已经逐渐在新的社交媒体环境中显现出来。在制作微…...

timm使用swin-transformer

1.安装 pip install timm2.timm中有多少个预训练模型 #timm中有多少个预训练模型 model_pretrain_list timm.list_models(pretrainedTrue) print(len(model_pretrain_list), model_pretrain_list[:3])3加载swin模型一般准会出错 model_ft timm.create_model(swin_base_pat…...

【java基础】java八大基本数据类型和运算符

文章目录说明八大基本数据类型整型浮点型字符型布尔类型类型转换java运算符基础运算符二元运算符自增自减运算符关系和boolean运算符三元运算符位运算符运算符优先级说明 这里介绍java的八大基本数据类型和运算符 八大基本数据类型 java中有八大数据类型&#xff0c;4个整型…...

Mybatis源码学习笔记(四)之Mybatis执行增删改查方法的流程解析

1 Mybatis流程解析概述 Mybatis框架在执行增伤改的流程基本相同&#xff0c; 很简单&#xff0c;这个大家只要自己写个测试demo跟一下源码,基本就能明白是怎么回事&#xff0c;查询操作略有不同&#xff0c; 这里主要通过查询操作来解析一下整个框架的流程设计实现。 2 Mybat…...

浅谈测试用例设计

前言 最近干的最多的事情就是设计测试用例、评审测试用例了&#xff0c;于是我不禁又想到了一个经典的问题&#xff1a;如何设计出优秀的测试用例&#xff1f; 可能有些童鞋看到这个问题会有些不以为然&#xff0c;这有什么好想的&#xff1f;干个测试谁还不会设计测试用例&a…...

python 利用装饰器实现类似于flask路由

例子1&#xff1a; def f1():print(1111)def f2():print(2222)if __name__ __main__:print(33)打印结果&#xff1a; 33 在例子1中&#xff0c;f1() 与f2() 都没有被调用&#xff0c;只执行了print(33) f1与f2&#xff0c;是没有被调用的&#xff0c;但是如果f1 和 f2 上面…...