Java集合汇总
Java中的集合框架是Java语言的核心部分,提供了强大的数据结构来存储和操作对象集合。集合框架位于java.util
包中,主要可以分为两大类:Collection(单列集合)和Map(双列集合)。下面是对它们的总结分类:
Collection(单列集合)
-
List(列表)
- ArrayList:基于动态数组实现,随机访问快,插入和删除慢(尤其是列表开头)。
- LinkedList:基于双向链表实现,插入和删除操作快,随机访问慢。
- Vector:线程安全的动态数组实现,功能类似于ArrayList,但因同步开销大,不推荐日常使用。
- Stack:继承自Vector,实现了后进先出(LIFO)栈的行为,但通常建议使用Deque作为栈。
以下是针对Java List集合(包括ArrayList、LinkedList、Vector、Stack)的一些基本使用方式和常用增删改查操作的汇总。请注意,尽管示例代码会以ArrayList为主,但大部分操作对于所有List实现都是通用的,除非特别说明。
增加元素
- add(E element):在列表末尾添加一个元素。
list.add("New Element");
- add(int index, E element):在指定位置插入元素。
list.add(0, "Inserted Element"); // 在索引0处插入
删除元素
- remove(Object o):删除第一次出现的指定元素。
list.remove("Element to Remove");
- remove(int index):根据索引删除元素。
list.remove(0); // 删除索引为0的元素
修改元素
- set(int index, E element):替换指定位置的元素。
list.set(0, "Updated Element"); // 将索引0处的元素更新
查询元素
- get(int index):返回指定位置的元素。
E element = list.get(0); // 获取索引0处的元素
- contains(Object o):检查列表是否包含指定元素。
boolean contains = list.contains("Search Element");
- size():返回列表中的元素数量。
int size = list.size();
遍历元素
- 使用增强型for循环:
for (E element : list) {System.out.println(element);
}
- 或者使用迭代器Iterator:
Iterator<E> iterator = list.iterator();
while (iterator.hasNext()) {E element = iterator.next();System.out.println(element);
}
特别注意
- 对于
Stack
,除了上述通用操作外,还可以使用push(E item)
和pop()
方法来模拟栈的“压栈”和“弹栈”操作。 Vector
的操作方式与ArrayList
相似,但由于线程安全设计,在多线程环境下无需额外的同步措施,但通常推荐使用Collections.synchronizedList(List<T> list)
或CopyOnWriteArrayList
作为替代,以获得更好的性能。
请根据实际需求选择合适的List实现,并注意它们在并发访问时的安全性和性能差异。
-
set集合
- HashSet:基于哈希表实现,无序、不允许重复元素,性能依赖于哈希码的质量。
- LinkedHashSet:基于哈希表与双向链表实现,保持插入顺序,不允许重复元素。
- TreeSet:基于红黑树实现,自然排序或自定义比较器排序,不允许重复元素。
对于Set集合中的HashSet
, LinkedHashSet
, 和 TreeSet
,它们的增删查操作基本一致,因为它们都遵循Set
接口的规范,但各自的特性和内部实现有所不同。下面是它们共有的常用操作方法以及一些特定于实现的特性说明:
共同的增删查方法
-
添加元素:
add(E element)
向集合中添加一个元素。如果该元素已经存在于集合中(根据对象的equals方法判断),则此操作不会改变集合,并返回false。否则,元素会被成功添加并返回true。 -
删除元素:
remove(Object o)
从集合中移除指定的对象。如果集合中存在该元素(根据equals方法判断),则会将其移除并返回true,否则返回false。 -
检查元素是否存在:
contains(Object o)
判断集合中是否包含指定的元素,基于对象的equals方法进行比较。 -
清空集合:
clear()
移除集合中的所有元素。 -
获取集合大小:
size()
返回集合中的元素数量。
特定实现的注意事项
-
HashSet
- 无序存储,不保证插入顺序。
- 性能最优,特别是在元素的哈希码分布良好的情况下。
- 特有方法:无,因为HashSet主要依赖于其基础的哈希表特性。
-
LinkedHashSet
- 除了基于哈希表实现外,还维护了一个双向链表来记录插入顺序。
- 提供了迭代时的插入顺序保证。
- 性能略低于HashSet,因为需要维护额外的链表结构。
-
TreeSet
- 基于红黑树实现,自然排序或自定义比较器排序,保证元素有序。
- 提供了丰富的排序相关操作,如
first()
,last()
,higher(E e)
,lower(E e)
等,可以方便地获取集合中的最小、最大或指定范围的元素。 - 插入、删除和查找的时间复杂度通常是O(log n),其中n是集合中的元素数量。
- 特有方法:可以通过构造函数传入Comparator来自定义排序逻辑。
示例代码片段
// 创建集合实例
Set<String> hashSet = new HashSet<>();
Set<String> linkedHashSet = new LinkedHashSet<>();
Set<String> treeSet = new TreeSet<>();// 添加元素
hashSet.add("Apple");
linkedHashSet.add("Banana");
treeSet.add("Cherry");// 删除元素
hashSet.remove("Apple");// 检查元素
boolean contains = treeSet.contains("Cherry");// 集合大小
int size = linkedHashSet.size();// 清空集合
treeSet.clear();
这些方法为操作Set集合的基本手段,具体选择哪种实现应根据是否需要有序性、是否关心插入顺序或是否有特定的排序需求等因素来决定。
Map(双列集合)
- HashMap:基于哈希表实现,键值对映射,非线程安全,允许null键和null值。
- LinkedHashMap:基于哈希表与双向链表实现,维护插入顺序或访问顺序。
- TreeMap:基于红黑树实现,键自然排序或自定义比较器排序,键唯一。
- Hashtable:线程安全的哈希表,较老的实现,不推荐用于新代码,已被ConcurrentHashMap取代。
- ConcurrentHashMap:线程安全的哈希表,支持高效并发读写,优于Hashtable。
对于Map集合中的HashMap
, LinkedHashMap
, TreeMap
, Hashtable
, 和 ConcurrentHashMap
,它们都遵循Map接口,提供了一套共同的操作方法来管理键值对,但也各有特色。以下是一些常见的操作方法及其特定实现的特点:
共同的增删查方法
-
添加/更新元素:
put(K key, V value)
将指定的键值对放入此映射中。如果此映射中已存在该键的映射关系,则旧值将被替换。 -
获取元素:
get(Object key)
根据键获取对应的值,如果键不存在则返回null。 -
删除元素:
remove(Object key)
根据键删除对应的映射关系,如果存在则返回被删除的值。 -
检查键是否存在:
containsKey(Object key)
判断映射中是否包含指定的键。 -
检查值是否存在:
containsValue(Object value)
判断映射中是否包含指定的值。 -
清空映射:
clear()
移除此映射中的所有映射关系。 -
获取映射大小:
size()
返回此映射中的键值对数量。
特定实现的特性与操作
-
HashMap
- 特点:非线程安全,允许null键和null值,性能较高,特别是当哈希码分布良好时。
- 特有方法:无特别独有的方法,重点在于其非线程安全性和性能优势。
-
LinkedHashMap
- 特点:维护了插入顺序或访问顺序(通过构造函数指定),基于HashMap实现,提供了迭代时的顺序保证。
- 特有方法:无特定新增方法,主要是通过构造函数控制迭代顺序的特性。
-
TreeMap
- 特点:键自然排序或自定义比较器排序,保证了键的有序性,基于红黑树实现。
- 特有方法:提供了丰富的基于排序的操作,如
firstKey()
,lastKey()
,lowerEntry(K key)
,higherEntry(K key)
等。
-
Hashtable
- 特点:线程安全的哈希表,较老的实现,不允许null键和null值,同步操作可能导致性能下降。
- 特有方法:相对较少特有方法,主要是其线程安全性的实现方式已过时。
-
ConcurrentHashMap
- 特点:线程安全,支持高效的并发读写,通过分段锁技术降低了锁的竞争,优于Hashtable。
- 特有方法:提供了一些高级并发操作,如
putIfAbsent(V value, K key)
,replace(K key, V oldValue, V newValue)
等,这些操作在原子性上有更好的保证。
示例代码片段
// 创建映射实例
Map<String, Integer> hashMap = new HashMap<>();
Map<String, Integer> linkedHashMap = new LinkedHashMap<>(16, 0.75f, true); // 第三个参数true表示按访问顺序排序
Map<String, Integer> treeMap = new TreeMap<>(); // 自然排序
Map<String, Integer> hashtable = new Hashtable<>();
Map<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();// 添加元素
hashMap.put("One", 1);// 获取元素
Integer value = hashMap.get("One");// 删除元素
hashMap.remove("One");// 检查键是否存在
boolean containsKey = hashMap.containsKey("One");// 获取映射大小
int size = hashMap.size();// 清空映射
hashMap.clear();
根据具体需求选择合适的Map实现,比如需要线程安全时考虑ConcurrentHashMap
,需要维持插入顺序时选择LinkedHashMap
,需要键有序时使用TreeMap
。
Queue(队列)
- Queue 接口,代表一个先进先出(FIFO)的队列。
- LinkedList:也可作为队列使用。
- PriorityQueue:基于优先堆的无界优先队列,没有固定顺序,元素按照自然排序或比较器排序。
- ArrayBlockingQueue:基于数组的有界阻塞队列,线程安全。
- LinkedBlockingQueue:基于链表的可选有界阻塞队列,线程安全。
- DelayQueue:基于优先级队列的延迟无界阻塞队列,元素只有在延迟期满后才能被获取。
- ConcurrentLinkedQueue:基于链表的无界并发队列,线程安全,非阻塞。
对于Java中的Queue接口及其常见实现,包括LinkedList
, PriorityQueue
, ArrayBlockingQueue
, LinkedBlockingQueue
, DelayQueue
, 和 ConcurrentLinkedQueue
,它们作为队列的主要操作包括入队(添加元素)、出队(移除并获取元素)、查看队首元素等。下面是它们的使用方式和基本操作的汇总:
公共操作
-
入队(添加元素)
add(E element)
:如果队列未满,则添加元素,队满时抛出IllegalStateException
。offer(E element)
:尝试加入元素,队列满时返回false
,而不是抛出异常。put(E element)
:对于阻塞队列(如ArrayBlockingQueue
,LinkedBlockingQueue
),如果队列满,当前线程将被阻塞,直到空间可用。
-
出队(移除并获取元素)
remove()
或poll()
:移除并返回队首元素,队列为空时,remove()
抛出异常,而poll()
返回null
。take()
:对于阻塞队列,如果队列为空,当前线程将被阻塞,直到有元素可用。
-
查看队首元素
element()
或peek()
:返回队首元素但不移除,队列为空时,element()
抛出异常,peek()
返回null
。
特定实现的特性
-
LinkedList
- 作为动态数组实现的List,也可以当作FIFO队列使用,但不支持阻塞操作。
- 常用操作:直接调用
addLast(E element)
入队,removeFirst()
或pollFirst()
出队。
-
PriorityQueue
- 基于优先堆的无界优先队列,保证最高优先级的元素先出队。
- 特有操作:无特定的队列操作,但其排序特性(基于自然排序或Comparator)是其特色。
-
ArrayBlockingQueue
- 固定大小的阻塞队列,线程安全。
- 特有操作:支持公平策略和非公平策略的阻塞控制。
-
LinkedBlockingQueue
- 可选固定大小的阻塞队列,基于链表实现,线程安全。
- 特有操作:默认无界(除非构造时指定了容量),提供了阻塞和非阻塞的put/take操作。
-
DelayQueue
- 基于优先级队列的无界阻塞队列,元素需实现
Delayed
接口,只有延迟到期的元素才可被消费。 - 特有操作:入队元素需实现
getDelay()
方法,以确定其到期时间。
- 基于优先级队列的无界阻塞队列,元素需实现
-
ConcurrentLinkedQueue
- 无界的并发队列,基于链表实现,线程安全,非阻塞。
- 特有操作:专门设计用于高并发场景,无需锁定,采用CAS操作保证线程安全。
示例代码片段
Queue<String> queue;// 使用LinkedList作为队列
queue = new LinkedList<>();
queue.offer("A");
queue.poll();// 使用PriorityQueue
queue = new PriorityQueue<>();
queue.offer("B");
queue.poll();// 使用ArrayBlockingQueue(阻塞队列)
queue = new ArrayBlockingQueue<>(10);
queue.put("C");
queue.take();// 使用LinkedBlockingQueue
queue = new LinkedBlockingQueue<>();
queue.put("D");
queue.take();// 使用DelayQueue
queue = new DelayQueue<>();
queue.put(new DelayedElement("Delayed E"));
queue.take();// 使用ConcurrentLinkedQueue
queue = new ConcurrentLinkedQueue<>();
queue.offer("F");
queue.poll();
请注意,使用DelayQueue
时,元素必须实现Delayed
接口,并重写getDelay()
方法和compareTo()
方法。
Deque(双端队列)
- Deque 接口,扩展了Queue,允许两端进行插入和删除操作。
- ArrayDeque:基于可调整大小的数组实现,可作为栈或队列使用,非线程安全。
- LinkedList:同样实现了Deque接口,提供了双端队列的功能。
对于Java中的Deque
接口及其两个主要实现类ArrayDeque
和LinkedList
,它们提供了丰富的双端队列操作,支持在队列的头部和尾部进行高效的插入和删除。以下是它们的使用方式和常用操作的汇总:
公共操作(适用于ArrayDeque和LinkedList)
-
在前端操作
- 插入:
addFirst(E element)
/offerFirst(E element)
在队列头部添加元素。 - 移除:
removeFirst()
/pollFirst()
移除并返回队列头部的元素;如果队列为空,removeFirst()
会抛出异常,而pollFirst()
返回null。 - 查看:
getFirst()
/peekFirst()
查看队列头部的元素但不移除;如果队列为空,getFirst()
抛出异常,peekFirst()
返回null。
- 插入:
-
在后端操作
- 插入:
addLast(E element)
/offerLast(E element)
在队列尾部添加元素。 - 移除:
removeLast()
/pollLast()
移除并返回队列尾部的元素;如果队列为空,removeLast()
抛出异常,pollLast()
返回null。 - 查看:
getLast()
/peekLast()
查看队列尾部的元素但不移除;如果队列为空,getLast()
抛出异常,peekLast()
返回null。
- 插入:
-
其他通用操作
- 大小查询:
size()
返回队列中元素的数量。 - 是否为空:
isEmpty()
判断队列是否为空。
- 大小查询:
实现类特性
-
ArrayDeque
- 特点:基于可调整大小的环形数组实现,提供了非常高的访问和修改性能,特别是对于随机访问和循环迭代。非线程安全,适用于不需要线程同步的高性能场景。
- 优势:在大多数场景下,由于其底层数据结构的优化,性能优于
LinkedList
。
-
LinkedList
- 特点:基于双向链表实现,既是List也是Deque,因此支持更多的操作,如索引访问等。适合于需要频繁进行插入和删除操作的场景,尤其是当这些操作发生在集合中间时。非线程安全。
- 优势:对于插入、删除操作,尤其是在链表中间的操作,表现优秀,但随机访问性能不如
ArrayDeque
。
示例代码片段
Deque<String> deque;// 使用ArrayDeque
deque = new ArrayDeque<>();
deque.addFirst("Front");
deque.addLast("Back");
String first = deque.peekFirst(); // 查看队首元素
deque.pollLast(); // 移除并返回队尾元素// 使用LinkedList作为Deque
deque = new LinkedList<>();
deque.offerFirst("Front");
deque.offerLast("Back");
String last = deque.peekLast(); // 查看队尾元素
deque.pollFirst(); // 移除并返回队首元素
根据具体需求选择合适的数据结构:对于追求性能和简单操作的场景,ArrayDeque
可能是更好的选择;而对于需要更多灵活性和链表特性的操作,LinkedList
会更加适用。
以上是Java集合框架的主要组成部分,它们为处理和操作集合提供了高度灵活和强大的工具。选择合适的集合类型取决于具体的应用场景,如是否需要线程安全、是否关心元素的顺序、是否需要排序等。
相关文章:

Java集合汇总
Java中的集合框架是Java语言的核心部分,提供了强大的数据结构来存储和操作对象集合。集合框架位于java.util包中,主要可以分为两大类:Collection(单列集合)和Map(双列集合)。下面是对它们的总结…...

度小满金融大模型的应用创新
XuanYuan/README.md at main Duxiaoman-DI/XuanYuan GitHub...

Android WebView上传文件/自定义弹窗技术,附件的解决方案
安卓内核开发 其实是Android的webview默认是不支持<input type"file"/>文件上传的。现在的前端页面需要处理的是: 权限 文件路径AndroidManifest.xml <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE"/&g…...
selenium 输入框、按钮,输入点击,获取元素属性等简单例子
元素操作 nput框 输入send_keys, input框 清除clear(), 按钮 点击click() 按钮 提交submit() 获取元素 tag_name、 class属性值、 坐标尺寸 """ input框 输入1次,再追加输入一次, 清除, 再重新输入&…...
结构体构造函数
【知识点:结构体构造函数】下面两段代码等价。 (1)结构体构造函数写法 struct LinkNode {int data;LinkNode* next;LinkNode(int x):data(x),next(NULL) {} }; LinkNode* Lnew LinkNode(123); (2)非结构体构造函数写…...
基于单片机的电子万年历设计
摘要: 本设计以 AT89C51 单片机为主控器,使用 DS1302 时钟芯片、DS18B20 温度芯片、LCD1602 显示模块,利用Proteus 仿真软件和 Keil 编译软件进行了基于单片机的电子万年历仿真,设计的万年历可以在液晶上显示时间,同时还具有时间校准、温度显示等功能。 关键词 :单片机…...

大厂真实面试题(一)
滴滴大数据sql 取出累计值与1000差值最小的记录 1.题目 已知有表t_cost_detail包含id和money两列,id为自增,请累加计算money值,并求出累加值与1000差值最小的记录。 2.分析 本题主要是想找到累加值域1000差距最小的记录,也就是我们要对上述按照id进行排序并且累加,并…...

Docker搭建ELKF日志分析系统
Docker搭建ELKF日志分析系统 文章目录 Docker搭建ELKF日志分析系统资源列表基础环境一、系统环境准备1.1、创建所需的映射目录1.2、修改系统参数1.3、单击创建elk-kgc网络桥接 二、基于Dockerfile构建Elasticsearch镜像2.1、创建Elasticsearch工作目录2.2、上传资源到指定工作路…...

把系统引导做到U盘,实现插上U盘才能开机
前言 有个小伙伴提出了这样一个问题:能不能把U盘制作成电脑开机的钥匙? 小白稍微思考了一下,便做了这样一个回复:可以。 至于为什么要思考一下,这样会显得我有认真思考他提出的问题。 Windows7或以上系统均支持UEF…...

【计算机网络基础知识】
首先举一个生活化的例子,当你和朋友打电话时,你可能会使用三次握手和四次挥手的过程进行类比: 三次握手(Three-Way Handshake): 你打电话给朋友:你首先拨打你朋友的电话号码并等待他接听。这就…...

个股场外期权个人如何参与买卖?
个股场外期权作为一种金融衍生品,为个人投资者提供了多样化的投资选择和风险管理工具。想要参与个股场外期权的买卖,以下是一些关键步骤和考虑因素。 文章来源/:财智财经 第一步:选择合适的金融机构 首先,个人投资者需…...

程序猿大战Python——pycharm软件的使用
基础配置 目标:了解PyCharm软件的基础配置处理。 修改背景颜色: Appearance -> Theme 修改字体大小: 搜索font -> Font 例如,一起完成背景、字体大小的修改。 总结: (1)如果要对PyChar…...

Unity Standard shader 修改(增加本地坐标裁剪)
本想随便找一个裁剪的shader,可无奈的是没找到一个shader符合要求,美术制作的场景都是用的都标准的着色器他们不在乎你的功能逻辑需求,他们只关心场景的表现,那又找不到和unity标准着色器表现一样的shader 1.通过贴图的透明通道做…...

【数据结构】排序——插入排序,选择排序
前言 本篇博客我们正式开启数据结构中的排序,说到排序,我们能联想到我之前在C语言博客中的冒泡排序,它是排序中的一种,但实现效率太慢,这篇博客我们介绍两种新排序,并好好深入理解排序 💓 个人主…...
2024.6.9刷题记录
目录 一、1103. 分糖果 II 1.模拟 2.数学 二、312. 戳气球 1.递归-记忆化搜索 2.区间dp 三、2. 两数相加 1.迭代 2.递归-新建节点 3.递归-原节点 四、4. 寻找两个正序数组的中位数 1.堆 2.双指针二分 五、5. 最长回文子串 1.动态规划 2.中心扩展算法 六、6. Z…...

Matlab|遗传粒子群-混沌粒子群-基本粒子群
目录 1 主要内容 2 部分代码 3 效果图 4 下载链接 1 主要内容 很多同学在发文章时候最犯愁的就是创新点创新点创新点(重要的事情说三遍),对于采用智能算法的模型,可以采用算法改进的方式来达到提高整个文章创新水平的目的&…...

31|HTTP3:甩掉TCP、TLS 的包袱,构建高效网络
前面两篇文章我们分析了HTTP/1和HTTP/2,在HTTP/2出现之前,开发者需要采取很多变通的方式来解决HTTP/1所存在的问题,不过HTTP/2在2018年就开始得到了大规模的应用,HTTP/1中存在的一大堆缺陷都得到了解决。 HTTP/2的一个核心特性是…...

2 程序的灵魂—算法-2.2 简单算法举例-【例 2.3】
【例 2.3】判定 2000 — 2500 年中的每一年是否闰年,将结果输出。 润年的条件: 1. 能被 4 整除,但不能被 100 整除的年份; 2. 能被 100 整除,又能被 400 整除的年份; 设 y 为被检测的年份,则算法可表示如下…...
Python中的上下文管理器(contextlib)模块
Python中的contextlib模块提供了一些用于创建和管理上下文管理器(context managers)的工具。上下文管理器是实现了__enter__()和__exit__()方法的对象,它们通常用于确保在代码块执行前后执行某些操作,比如资源获取与释放、设置和重…...

C语言:定义和使用结构体变量
定义和使用结构体变量 介绍基础用法1.定义结构体2. 声明结构体变量3. 初始化和访问结构体成员4. 使用指针访问结构体成员5. 使用结构体数组 高级用法6. 嵌套结构体7. 匿名结构体8. 结构体和动态内存分配9. 结构体作为函数参数按值传递按引用传递 介绍 在C语言中,结…...
ES6从入门到精通:前言
ES6简介 ES6(ECMAScript 2015)是JavaScript语言的重大更新,引入了许多新特性,包括语法糖、新数据类型、模块化支持等,显著提升了开发效率和代码可维护性。 核心知识点概览 变量声明 let 和 const 取代 var…...
在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module
1、为什么要修改 CONNECT 报文? 多租户隔离:自动为接入设备追加租户前缀,后端按 ClientID 拆分队列。零代码鉴权:将入站用户名替换为 OAuth Access-Token,后端 Broker 统一校验。灰度发布:根据 IP/地理位写…...

页面渲染流程与性能优化
页面渲染流程与性能优化详解(完整版) 一、现代浏览器渲染流程(详细说明) 1. 构建DOM树 浏览器接收到HTML文档后,会逐步解析并构建DOM(Document Object Model)树。具体过程如下: (…...

12.找到字符串中所有字母异位词
🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...

浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...

【分享】推荐一些办公小工具
1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由:大部分的转换软件需要收费,要么功能不齐全,而开会员又用不了几次浪费钱,借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?
在工业自动化持续演进的今天,通信网络的角色正变得愈发关键。 2025年6月6日,为期三天的华南国际工业博览会在深圳国际会展中心(宝安)圆满落幕。作为国内工业通信领域的技术型企业,光路科技(Fiberroad&…...

沙箱虚拟化技术虚拟机容器之间的关系详解
问题 沙箱、虚拟化、容器三者分开一一介绍的话我知道他们各自都是什么东西,但是如果把三者放在一起,它们之间到底什么关系?又有什么联系呢?我不是很明白!!! 就比如说: 沙箱&#…...
拟合问题处理
在机器学习中,核心任务通常围绕模型训练和性能提升展开,但你提到的 “优化训练数据解决过拟合” 和 “提升泛化性能解决欠拟合” 需要结合更准确的概念进行梳理。以下是对机器学习核心任务的系统复习和修正: 一、机器学习的核心任务框架 机…...

qt+vs Generated File下的moc_和ui_文件丢失导致 error LNK2001
qt 5.9.7 vs2013 qt add-in 2.3.2 起因是添加一个新的控件类,直接把源文件拖进VS的项目里,然后VS卡住十秒,然后编译就报一堆 error LNK2001 一看项目的Generated Files下的moc_和ui_文件丢失了一部分,导致编译的时候找不到了。因…...