最新资讯

  • 【C++】list 容器最全详解(什么是list? list容器的常用接口有那些?)

【C++】list 容器最全详解(什么是list? list容器的常用接口有那些?)

2025-05-06 05:01:07 4 阅读

目录

一、前言

二、 什么是 list ?

💦 list 的存储结构  

 💦 list 容器的优点

 💦 list 容器的缺点

 三、list 容器的定义

 四、list 容器常用接口的使用

 💦list 的常见构造(初始化)

💦list 的遍历及迭代器的操作

 ① 迭代器

 ② 范围for

 💦list 容器的常见容量操作

 ① size

 ② resize 

 ③ empty

 ④ clear

 💦list 容量的常见访问操作

 ①  front()——访问list头元素

 ②  back()——访问list尾元素

 💦list 容器的常见修改操作

① push_back()——添加元素(list尾部)

② pop_back()——移除list元素(尾部)

③ pop_front()——删除list元素(头部)

④ push_front()——添加元素(list头部)

⑤ insert()——添加元素(任意位置)

⑥ erase()——删除元素(任意位置) 

⑦ swap()——交换元素 

 💦list 容器的常见操作函数

① splice()——从另一个list中移动元素

② remove()——移除特定值的元素

③ remove_if()——移除满足特定标准的元素 

④ unique()——删除连续的重复元素 

⑤ sort()——对元素进行排序 

⑥ merge()——合并list 

⑦ reverse()——将该链表的所有元素的顺序反转 【C++11】 

⑧ assign()——将值赋给容器

 五、vector 与 list  的对比

六、共勉


一、前言

        最近在刷 leetcode 的时候,发现 list 都还没弄明白吗,但是 STL 的强大是众所周知滴,早晚都是要解决滴,因此专门写下这篇文章,以供自己复习和各位老铁使用,快速的回忆 list 的用法,让你找回自信,不用再竞赛的时候颜面尽失。
       本次博客主要讲解
list 容器基本操作、常用接口做一个系统的整理,结合具体案例熟悉自定义内部排序方法的使用,请大家持续关注我O!!

二、 什么是 list ?

     listC++的一个序列容器插入和删除元素的效率较高时间复杂度常数级别list容器的底层数据结构为带头双向循环链表,这使得 list的元素可以存储在非相邻的内存中,在list内部,不同元素之间通过指向前一个元素的指针以及指向后一个元素的指针相关联。
    

     list 容器与其他序列容器如vector deque array相比,由于其底层数据结构为带头双向循环链表,因此 list 在插入删除元素方面很有优势在列表的任意位置进行插入和删除操作的时间复杂度为O(1)。但不能直接通过位置(下标)来直接访问元素。想要访问list的某个元素,必须从list的一端(或已知位置)迭代到该元素。另外,list还需要额外的存储空间来储存前一个元素和后一个元素的链接信息。

💦 list 的存储结构  

        list 容器底层为带头双向循环链表,带头双向循环链表每个节点包含指向前驱节点的pre指针,指向后继节点的next指针以及节点的数据。list存储结构如下图所示: 哨兵节点表示 链表的第一个元素节点,且不保存任何数据
 

 如果还有老铁对 带头双向循环链表不太了解的可以看看这篇文章:详解带头双向循环链表

 💦 list 容器的优点

  •  高效的插入和删除:由于std::list是基于带头双向循环链表实现的,插入和删除操作在任意位置都具有常数时间复杂度O(1),不需要移动其他元素。这使得std::list在需要频繁插入和删除元素的场景下非常高效。
  • 稳定的迭代器:在std::list中进行插入和删除操作不会使得迭代器失效。这意味着在插入或删除元素后,仍然可以继续使用之前获取的迭代器进行遍历和操作。
  • 动态内存管理:std::list可以动态调整大小,根据需要分配和释放内存。这使得std::list能够有效地处理大量元素的情况,而不会浪费过多的内存空间。

 💦 list 容器的缺点

  • 低效的随机访问:由于std::list的存储结构是带头双向循环链表,访问元素时需要从头或尾开始遍历链表,因此在列表中进行随机访问的效率较低。获取特定位置的元素需要遍历链表,时间复杂度为O(n),其中n是元素的总数量。
  • 占用额外内存:相较于其他容器,std::list在存储上需要额外的指针来维护链表结构,因此在存储大量元素时,它可能占用更多的内存空间。
  • 迭代器不支持指针算术:std::list的迭代器不支持指针算术运算,无法像指针那样直接进行加减操作,这限制了一些操作的灵活性。

头文件:
list是C++ 标准模板库的一部分,因此,想要使用list,需要在程序中包含头文件 list

#include

 三、list 容器的定义

 单独定义一个 list

list  name;

        这里的typename可以是任何基本类型,例如int、double、char、结构体等,也可以是STL标准容器,例如string、set、queue、vector等。
       注意:使用前必须加上头文件:#include
代码展示:

#include 
#include 
using namespace std;
int main()
{
	int a[3];               // 正常定义的-----静态数组

	list str_a;        // list 定义的 int类型的链表

	char b[3];

	list str_b;
	return 0;
}

 四、list 容器常用接口的使用

 💦list 的常见构造(初始化)

接口名称接口说明
list()   (⭐)构造空的list
list (size_type n, const value_type& val = value_type())构造的list中包含n个值为val的元素
list (const list& x)(⭐)拷贝构造函数
list (InputIterator first, InputIterator last用[first, last)区间中的元素构造list

 注意: ⭐表示重点掌握

 方式一: 构造一个某类型的空容器
list<数据类型> 函数名; 初始化为空。

list lt1; //构造int类型的空容器

方式二: 构造一个含有n个val的某类型容器:

list lt2(10, 2); //构造含有10个2的int类型容器

方式三: 拷贝构造某类型容器的复制品:

list lt3(lt2); //拷贝构造int类型的lt2容器的复制品

方式四: 使用迭代器拷贝构造某一段内容:

string s("hello world");
list lt4(s.begin(),s.end()); //构造string对象某段迭代器区间的内容

方式五: 构造数组某段区间的内容:

int arr[] = { 1, 2, 3, 4, 5 };
int sz = sizeof(arr) / sizeof(int);
list lt5(arr, arr + sz); //构造数组某段区间的复制品  ->本质是调用迭代器区间的构造函数

方式五: 使用花括号构造内容(C++11):

list lt{ 1,2,3,4,5 };  // 直接使用花括号进行构造---C++11允许

代码展示1(实用):

#include 
#include 
using namespace std;
int main()
{
	list frist;                                   // 构造一个没有元素的空容器
	list second(2, 10);                           // 2个值为10的整数
	list third(second.begin(), second.end());     // 迭代器构造
	list fourth(third);                           // 拷贝构造


	// 迭代器构造函数也可以使用数组来进行构造,传的区间是左闭右开
	// 因为指向数组空间的指针是天然的迭代器
	int arr[] = { 16,2,77,29 };
	list fifth(arr, arr + 4);
	// std::list fifth (arr, arr + sizeof(arr) / sizeof(int) );

	// first : []
	// second: [10,10]
	// third : [10,10]
	// fourth: [10,10]
	// fifth : [16,2,77,29]
	return 0;
}

效果展示:



代码展示2不实用):

#include 
#include 
using namespace std;
int main()
{
	// 用其它容器的迭代器初始化,只要数据d类型可以匹配上
	string s("hello");
	list v(s.begin(), s.end());
	for (auto& e : v)
	{
		cout << e << " ";
	}
	cout << endl;

	return 0;
}

💦list 的遍历及迭代器的操作

接口名称接口说明
 迭代器(⭐) begin()  + end()  或者  rbegin() + rend()
范围forC++11支持更简单的for的新遍历方式(底层还是借用迭代器实现)

注意:遍历链表-------只能用**迭代器**和**范围for**

  • begin与end为正向迭代器,对迭代器执行++操作,迭代器向后移动
  • rbegin(end)与rend(begin)为反向迭代器,对迭代器执行++操作,迭代器向前移动

 ① 迭代器

接口名称接口说明
begin()(⭐)返回第一个元素的迭代器
end()(⭐)返回最后一个元素下一个位置的迭代器
rbegin()返回最后一个元素的迭代器
rend()返回第一个元素的前一个位置额迭代器

  begin  和 end

  • 通过begin函数可以得到容器中第一个元素的正向迭代器,通过end函数可以得到容器中最后一个元素的后一个位置的正向迭代器。

正向迭代器遍历容器:

#include 
#include 
using namespace std;
int main()
{
	int array[] = { 1,2,3,4,5,6,7,8 };
	// 用已有的数组 初始化 list 链表
	list lt(array, array + sizeof(array) / sizeof(array[0]));
	// 正向迭代器遍历容器
	list::iterator it = lt.begin();
	// 开始循环遍历
	while (it != lt.end())
	{
		cout << *it << " ";    // 1 2 3 4 5 6 7 8
		it++;
	}
	cout << endl;
	return 0;
}
  • 注意:begin与end为正向迭代器,对迭代器执行++操作,迭代器向后移动

 rbegin和rend

  • 通过rbegin函数可以得到容器中最后一个元素的反向迭代器,通过rend函数可以得到容器中第一个元素的前一个位置的反向迭代器。

反向迭代器遍历容器:

#include 
#include 
using namespace std;
int main()
{
	int array[] = { 1,2,3,4,5,6,7,8 };
	// 用已有的数组 初始化 list 链表
	list lt(array, array + sizeof(array) / sizeof(array[0]));
	// 正向迭代器遍历容器
	list::reverse_iterator it = lt.rbegin();
	// 开始循环遍历
	while (it != lt.rend())
	{
		cout << *it << " ";    // 8 7 6 5 4 3 2 1
		it++;
	}
	cout << endl;
	return 0;
}
  • 注意:rbegin(end)与rend(begin)为反向迭代器,对迭代器执行++操作,迭代器向前移动

 ② 范围for

 如果支持迭代器的话,一定支持范围for

#include 
#include 
#include 
using namespace std;
int main()
{
	vector v{ 1,2,3,4,5 };
	list lt(v.begin(), v.end());
	// C++ 范围for 的方式遍历

	for (auto& e : lt)
	{
		cout << e << " ";
	}
	cout << endl;
	// 输出 :1 2 3 4 5
	return 0;
}

 💦list 容器的常见容量操作

接口名称接口说明
size返回容器中有效元素个数
resize(调整容器的有效元素大小(size)
empty判断容器是否为空
clear用于清空容器,清空后容器的size为0, 但是头结点(哨兵位)不会被清除

 ① size

size函数用于获取当前容器当中的元素个数,

#include 
#include 
using namespace std;

int main()
{
	list lt;
	lt.push_back(1);
	lt.push_back(2);
	lt.push_back(3);
	lt.push_back(4);
	cout << lt.size() << endl; //4
	return 0;
}

② resize 

 在C++中,list 容器提供了resize()方法,用于调整列表的大小。使用resize()方法可以重新指定list的大小,并根据需要插入或删除list中的元素来达到指定的大小。

 resize()方法有两种重载形式:

  •  void resize(size_type count, const T& value = T()):

        这个重载会将列表的大小调整为count。如果count大于当前列表的大小,则在列表末尾插入足够数量的值为value的元素。如果count小于当前列表的大小,则删除超出count的元素。 

  • void resize(size_type count): 

       这个重载会将列表的大小调整为count。如果count大于当前列表的大小,则在列表末尾插入默认构造的元素。如果count小于当前列表的大小,则删除超出count的元素。

 代码示例:

#include 
#include 
using namespace std;
int main() 
{
    list mylist = { 1, 2 };
    // 把mylist的大小设为5
    mylist.resize(5);
    cout << "第一次resize后list中元素为:";
    for (auto a : mylist) {
        cout << a << " ";
    }
    cout << endl;
    // 把mylist的大小设为1
    mylist.resize(1);
    cout << "第二次resize后list中元素为:";
    for (auto a : mylist) {
        cout << a << " ";
    }
    cout << endl;

    // 把list大小设为4,不足部分填充5
    mylist.resize(4, 5);
    cout << "第三次resize后list中元素为:";
    for (auto a : mylist) {
        cout << a << " ";
    }
    cout << endl;
}

 效果展示:

③ empty

 empty()方法用来判断list是否为空,如果为空,返回true;如果非空,返回false。示例如下:

💻示例代码💻 

#include
#include

using std::cout;
using std::endl;
using std::list;

int main () {
    list mylist1;
    list mylist2 = {1, 2};
    cout<< "mylist1是否为空?"<< mylist1.empty() << endl;
    cout<< "mylist2是否为空?"<< mylist2.empty() << endl;
}

 📄效果展示📄

 ④ clear

 clear 函数用于清空容器,清空后容器的size为0, 但是头结点(哨兵位)不会被清除

#include 
#include 
using namespace std;

int main()
{
	list lt(5, 2);
	for (auto e : lt)
	{
		cout << e << " ";
	}
	cout << endl; //2 2 2 2 2
	cout << lt.size() << endl; //5
	lt.clear(); //清空容器
	for (auto e : lt)
	{
		cout << e << " ";
	}
	cout << endl; //(无数据)
	cout << lt.size() << endl; //0
	return 0;
}

 💦list 容量的常见访问操作

 front()——访问list头元素

 front()返回list第一个元素
示例如下:

 💻示例代码💻

#include
#include

using std::cout;
using std::endl;
using std::list;

int main() {
    list mylist {1, 2, 3, 4, 5, 6, 7, 8};
    cout<< "初始化后的mylist为:";
    for (auto num : mylist) {
        cout<< num<< " ";
    }
    int front = mylist.front();   // 1

    cout<< "
mylist的头元素为:"<< front;
}

 ②  back()——访问list尾元素

back()返回list第一个元素
示例如下: 

💻示例代码💻 

#include
#include

using std::cout;
using std::endl;
using std::list;

int main() {
    list mylist {1, 2, 3, 4, 5, 6, 7, 8};
    cout<< "初始化后的mylist为:";
    for (auto num : mylist) {
        cout<< num<< " ";
    }
    int front = mylist.front();  // 8

    cout<< "
mylist的头元素为:"<< front;
}

 💦list 容器的常见修改操作

接口名称接口说明
push_front在list首元素前插入值为val的元素
pop_front删除list中第一个元素
push_back在list尾部插入值为val的元素
pop_back删除list中最后一个元素
insert在list position 位置中插入值为val的元素
erase删除list position位置的元素
swap交换两个list中的元素

① push_back()——添加元素(list尾部)

 向list中添加元素,使用push_back()方法,作用是向list尾部添加一个元素。示例如下:

 💻示例代码💻

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // 在list尾部插入一个元素8
    mylist.push_back(8);
    cout << "
尾部插入一个元素后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";       // 1 2 3 4 8
    }
}

② pop_back()——移除list元素(尾部)

删除list中的元素,使用pop_back()方法,作用是删除list尾部的一个元素。示例如下: 

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // 删除mydeue尾部一个元素
    mylist.pop_back();
    cout << "
尾部删除一个元素后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";   // 1 2 3
    }
}

 ③ pop_front()——删除list元素(头部)

 删除list中的元素,使用pop_front()方法,作用是删除list头部的一个元素。示例如下:

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // 删除mydeue头部一个元素
    mylist.pop_front();
    cout << "
头部删除一个元素后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";    // 2 3 4
    }
}

④ push_front()——添加元素(list头部)

 向list中添加元素,使用push_front()方法,作用是向list头部添加一个元素。示例如下:

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};

    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // 在list头部插入一个元素8
    mylist.push_front(8);

    cout << "
头部插入一个元素后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";  // 8 1 2 3 4
    } 
}

⑤ insert()——添加元素(任意位置)

向list中添加元素。 

insert共有三种形式:
- insert(iterator, value);
- insert(iterator, num, value);
- insert(iterator, iterator1, iterator2);
 

用法一:list.insert(iterator,value) 

        使用insert(iterator,value)方法,作用是向iterator迭代器指向元素的前边添加一个元素value,并返回一个迭代器指向新插入的元素。 

 💻示例代码💻

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // it指向mylist的第二个元素
    list::iterator it = mylist.begin() + 1;
    // 使用insert添加一个元素
    list::iterator itnew = mylist.insert(it, 10);
    cout << "
返回的迭代器指向的元素为" << *itnew;
    cout << "
insert添加一个元素后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
}

 📄输出📄

初始化后的mylist为:1 2 3 4
返回的迭代器指向的元素为10
insert添加一个元素后的mylist为:1 10 2 3 4 


用法二:list.insert(iterator,num,value) 

       使用insert(iterator,num,value)方法,作用是向iterator迭代器指向元素的前边添加num个元素value,并返回一个迭代器指向新插入的第一个元素.

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // it指向mylist的第二个元素
    list::iterator it = mylist.begin() + 1;

    // 使用insert添加2个元素,value为20
    mylist.insert(it, 2, 20);
    cout << "
使用insert插入元素后:";
    for (auto num : mylist) {
        cout << num << " ";
    }
}

 📄输出📄

初始化后的mylist为:1 2 3 4
使用insert插入元素后:1 20 20 2 3 4 


用法三:insert(iterator, iterator1, iterator2)

       使用insert(iterator, iterator1, iterator2);方法,作用是向iterator迭代器指向元素的前边添加[iterator1,iterator2)之间的元素。 
 

 💻示例代码💻

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // it指向mylist的第二个元素
    list::iterator it = mylist.begin() + 1;
    // 定义一个辅助list
    list list2{10, 20, 30};
    // it1指向list2的第一个元素
    list::iterator it1 = list2.begin();
    // it2指向list2的最后一个元素后一个位置
    list::iterator it2 = list2.end();
    // 使用insert在2之前添加[it1,it2)之间的元素
    mylist.insert(it, it1, it2);
    cout << "
使用insert插入元素后:";
    for (auto num : mylist) {
        cout << num << " ";
    }
}

 📄输出📄

初始化后的mylist为:1 2 3 4
使用insert插入元素后:1 10 20 30 2 3 4 

⑥ erase()——删除元素(任意位置) 

       ❤erase的作用就是根据传入的迭代器删除list中的元素,参数为一个迭代器,只删除迭代器指向的元素;参数为两个迭代器,删除两个迭代器之间的元素❤ 

 erase 共有 两 种形式:
- list.erase(iterator)
- list.erase(iterator1,iterator2)

 用法一:list.erase(iterator)

这种用法会删除迭代器iterator指向的元素。

 💻示例代码💻

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // it指向mylist的第二个元素
    list::iterator it = mylist.begin() + 1;
    // 删除it指向的元素,即2,并返回一个迭代器指向2之后的元素
    list::iterator itnew = mylist.erase(it);
    cout << "
删除元素后返回的迭代器itnew指向的元素为:" << *itnew;
    cout << "
使用erase删除元素后:";
    for (auto num : mylist) {
        cout << num << " ";
    }
}

 📄输出📄

初始化后的mylist为:1 2 3 4
删除元素后返回的迭代器itnew指向的元素为:3
使用erase删除元素后:1 3 4


 用法二:list.erase(iterator1,iterator2) 

    这种用法会删除迭代器iterator1指向的元素到iterator2指向元素之间的元素,包括iterator1指向的元素但不包括iterator2指向的元素,即擦除[iterator1,iterator2)。

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist{1, 2, 3, 4};
    cout << "初始化后的mylist为:";
    for (auto num : mylist) {
        cout << num << " ";
    }
    // it1指向mylist的第二个元素
    list::iterator it1 = mylist.begin() + 1;
    // it2指向mylist的最后一个元素后一个位置
    list::iterator it2 = mylist.end();

    // 删除[it1,it2)之间的元素,即删除2,3,4
    mylist.erase(it1, it2);
    cout << "
使用erase删除元素后:";
    for (auto num : mylist) {
        cout << num << " ";
    }
}

📄输出📄 

初始化后的mylist为:1 2 3 4
使用erase删除元素后:1

⑦ swap()——交换元素 

 ❤swap的作用就是交换两个list的元素

交换两个list的元素,使用swap()方法,list1.swap(list2),两个list存储的元素类型必须相同,元素个数可以不同。示例如下: 

💻示例代码💻 

#include 
#include 

using std::cout;
using std::list;
using std::endl;

int main() {
    list mylist1{1, 11, 111, 1111};
    list mylist2{2, 22, 222};
    cout << "初始化后的mylist1为:";
    for (auto num : mylist1) {
        cout << num << " ";
    }
    cout << "
初始化后的mylist1为:";
    for (auto num : mylist2) {
        cout << num << " ";
    }
    // 交换mylist1和mylist2的元素
    mylist1.swap(mylist2);
    cout << "
使用swap交换元素后mylist1:";
    for (auto num : mylist1) {
        cout << num << " ";
    }
    cout << "
使用swap交换元素后mylist2:";
    for (auto num : mylist2) {
        cout << num << " ";
    }
}

 📄输出📄

初始化后的mylist1为:1 11 111 1111
初始化后的mylist1为:2 22 222
使用swap交换元素后mylist1:2 22 222
使用swap交换元素后mylist2:1 11 111 1111 

 💦list 容器的常见操作函数

函数声明接口说明
splice将元素从列表转移到其它列表
remove删除具有特定值的元素
remove_if删除满足条件的元素
unique删除重复值
sort容器中的元素排序
merge合并排序列表

reverse

反转元素的顺序

 ① splice()——从另一个list中移动元素

 splice 方法用于将另一个 std::list 的元素插入到当前列表的指定位置。示例如下:

splice共有四种形式,分别为: 

  • splice(iterator_pos, otherList) : 将otherList中的所有元素移动到iterator_pos指向元素之前
  • splice(iterator_pos, otherList, iter1): 从 otherList转移 iter1 指向的元素到当前list。元素被插入到 iterator_pos指向的元素之前。
  • splice(iterator_pos, otherList, iter_start, iter_end) : 从 otherList转移范围 [iter_start, iter_end) 中的元素到 当前列表。元素被插入到 iterator_pos指向的元素之前。

 注意:

1. splice 操作不会进行元素的复制或移动,只是修改指针连接,因此效率较高。
2. 在 splice 操作后,被移动的元素将不再属于原始列表。
3. splice 操作后,原始列表和插入列表的大小会相应改变。
4. 插入操作的时间复杂度为 O(1) 

💻示例代码💻 

#include 
#include 

int main() {
    std::list list1 = {1, 2, 3, 4, 5};
    std::list list2 = {10, 20, 30};
    std::list list3 = {1, 2, 3, 4, 5};
    std::list list4 = {10, 20, 30};
    std::list list5 = {1, 2, 3, 4, 5};
    std::list list6 = {10, 20, 30};

    /*
       用法一 : splice(iterator_pos, otherList)
    */

    // 将list2中所有元素插入到list1的第一个位置
    list1.splice(list1.begin(), list2);
    // 输出结果
    std::cout<< "转移list2元素到list1之后的list1: ";
    for (int i : list1) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    std::cout<< "转移list2元素到list1之后的list1: ";
    for (int i : list2) {
        std::cout << i << " ";
    }
    std::cout << std::endl;

    /*
        用法二:splice(iterator_pos, otherList, iter1)
    */
    auto it = list3.begin();
    // 将迭代器向后移动两个位置,指向第三个元素
    std::advance(it, 2);
    // 将list4的第一个元素(10)插入到list3的第三个位置
    list3.splice(it, list4, list4.begin());
    // 输出结果
    std::cout<< "转移list4元素到list3之后的list3: ";
    for (int i : list3) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    std::cout<< "转移list4元素到list3之后的list4: ";
    for (int i : list4) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    /*
        用法三:splice(iterator_pos, otherList, iter_start, iter_end)
    */
    // 将list5中第二个到第四个元素移动到list6的末尾
    auto first = list5.begin();
    std::advance(first, 1);
    auto last = list5.begin();
    std::advance(last, 4);
    list6.splice(list6.end(), list5, first, last);

    // 输出结果
    std::cout<< "转移list5元素到list6之后的list5: ";
    for (int i : list5) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    std::cout<< "转移list5元素到list6之后的list6: ";
    for (int i : list6) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    return 0;
}

📄初始化的值📄 

std::list list1 = {1, 2, 3, 4, 5};
std::list list2 = {10, 20, 30};
std::list list3 = {1, 2, 3, 4, 5};
std::list list4 = {10, 20, 30};
std::list list5 = {1, 2, 3, 4, 5};
std::list list6 = {10, 20, 30};

 📄输出📄

转移list2元素到list1之后的list1: 10 20 30 1 2 3 4 5
转移list2元素到list1之后的list1:
转移list4元素到list3之后的list3: 1 2 10 3 4 5
转移list4元素到list3之后的list4: 20 30
转移list5元素到list6之后的list5: 1 5
转移list5元素到list6之后的list6: 10 20 30 2 3 4


 remove()——移除特定值的元素

std::list 的 remove 方法用于从列表中移除与指定值相等的元素。示例如下: 

💻示例代码💻 

#include 
#include 

int main() {
    std::list mylist {1, 2, 3, 4, 5};
    // 移除列表中所有值为2的元素
    mylist.remove(2);
    std::cout << "移除之后的mylist: ";
    for (const auto& element : mylist) {
        std::cout << element << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

移除之后的mylist: 1 3 4 5 


③ remove_if()——移除满足特定标准的元素 

使用方式:remove_if(func)

 使用 remove_if 方法可以从 mylist 中移除所有满足 函数func的元素,下边的例子中定义了一个函数isEven(),判断一个数字是否为偶数。示例如下:

💻示例代码💻 

#include 
#include 

bool isEven(int n) {
    return n % 2 == 0;
}
int main() {
    std::list mylist {1, 2, 3, 4, 5};
    // 移除列表中所有满足 isEven 的元素(偶数)
    mylist.remove_if(isEven);
    std::cout << "移除之后的mylist: ";
    for (const auto& element : mylist) {
        std::cout << element << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

移除之后的mylist: 1 3 5 


④ unique()——删除连续的重复元素 

 unique()方法用于移除链表中相邻且重复的元素,仅保留一个副本。示例如下:

💻示例代码💻 

#include 
#include 

int main() {
    std::list myList = {1, 2, 2, 3, 3, 4, 5, 5, 5};
    std::cout << "初始化后的list为: ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    myList.unique();
    std::cout << "执行unique后的list为: ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

初始化后的list为: 1 2 2 3 3 4 5 5 5
执行unique后的list为: 1 2 3 4 5 


⑤ sort()——对元素进行排序 

sort()方法用于对链表中的元素进行排序。默认情况下,它按升序对元素进行排序,使用元素类型的 < 运算符进行比较。示例如下: 

💻示例代码💻 

#include 
#include 

int main() {
    std::list myList = {5, 3, 2, 4, 1};
    std::cout << "初始化后的list为 ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    myList.sort();
    std::cout << "排序后的list为: ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

初始化后的list为 5 3 2 4 1
排序后的list为: 1 2 3 4 5 

⑥ merge()——合并list 

将两个已排序的列表合并成一个有序的列表。merge()方法将另一个列表的元素插入到调用方法的列表中,并保持排序顺序。示例如下: 

注意:merge()方法只能用于已排序的list。如果list未排序,则合并的结果将是不正确的。 

💻示例代码💻 

#include 
#include 
using namespace std;
int main() {
    std::list list1 = {1, 3, 5};
    std::list list2 = {2, 4, 6};
    cout << "初始化后的list1为:";
    for (auto num : list1) {
        cout << num << " ";
    }
    std::cout << std::endl;
    cout << "初始化后的list2为:";
    for (auto num : list2) {
        cout << num << " ";
    }
    std::cout << std::endl;
    // 将 list2 合并到 list1 中
    list1.merge(list2);
    // 输出合并后的列表
    cout << "合并后的list1为:";
    for (const auto& element : list1) {
        std::cout << element << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

初始化后的list1为:1 3 5
初始化后的list2为:2 4 6
合并后的list1为:1 2 3 4 5 6 

 ⑦ reverse()——将该链表的所有元素的顺序反转 【C++11】 

 reverse()方法用于反转链表中元素的顺序,即将链表中的第一个元素变为最后一个元素,第二个元素变为倒数第二个元素,以此类推。示例如下:

💻示例代码💻 

#include 
#include 

int main() {
    std::list myList = {1, 2, 3, 4, 5};
    std::cout << "初始化list为: ";
    for (const auto& element : myList) {
        std::cout << element << " ";
    }
    std::cout << std::endl;
    myList.reverse();
    std::cout << "Reversed后的list为: ";
    for (const auto& element : myList) {
        std::cout << element << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

初始化list为: 1 2 3 4 5
Reversed后的list为: 5 4 3 2 1 

 ⑧ assign()——将值赋给容器

assign()方法用于将链表中的元素替换为新的元素序列。它可以接受不同形式的参数,提供了两种重载形式。

  • 第一种形式接受迭代器范围作为参数,用于将另一个容器或数组中的元素复制到链表中。它会将链表清空,并将指定范围内的元素复制到链表中。void assign(InputIterator first, InputIterator last);
  • 第二种形式接受一个元素数量和一个值作为参数,用于将指定数量的相同值的元素分配给链表。它会将链表清空,并将指定数量的元素赋值为指定的值。void assign(size_type count, const T& value);

💻示例代码💻 

#include 
#include 
#include 

int main() {
    std::list myList;
    // 使用迭代器范围进行分配
    std::vector numbers = {1, 2, 3, 4, 5};
    myList.assign(numbers.begin(), numbers.end());
    std::cout << "第一次执行assign之后的list为: ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    // 使用元素数量和值进行分配
    myList.assign(3, 100);
    std::cout << "第二次执行assign之后的list为: ";
    for (auto i : myList) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    return 0;
}

 📄输出📄

第一次执行assign之后的list为: 1 2 3 4 5
第二次执行assign之后的list为: 100 100 100 

 五、vector 与 list  的对比

对比vectorlist
底层结构动态顺序表,连续空间带头结点的双向循环链表
访问支持随机访问,首地址+下标不能随机访问,可通过find查找,访问随即元素时间复杂度O(N)
插入删除任意位置插入和删除效率低,需要搬移元素,时间复杂度为O(N),插入时有可能需要增容,增容:开辟新空间,拷贝元素,释放旧空间,导致效率更低任意位置插入和删除效率高,不需要搬移元素,时间复杂度为O(1)
空间利用率底层为连续空间,不容易造成内存碎片,空间利用率较高,缓存利用率高。可以一次将一个数据附近的空间都加载到缓存,不用频繁地从内存读取数据底层节点动态开辟,容易造成内存碎片,空间利用率低,缓存利用率低
迭代器原生态指针对指针进行了封装
迭代器失效容量相关的操作都有可能导致迭代器失效,如插入引起的扩容,删除元素等插入元素不会导致迭代器失效,删除节点会导致,且只影响当前迭代器,其他迭代器不受影响
使用场景不关心插入和删除效率,支持随机访问大量插入和删除操作,不关心随机访问的场景

六、共勉

      以下就是我对 list 容器 的理解,如果有不懂和发现问题的小伙伴,请在评论区说出来哦,同时我还会继续更新对 C++ list容器的模拟实现请持续关注我哦!!!     

本文地址:https://www.vps345.com/8532.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP docker 容器 运维 java-rabbitmq java 服务器 linux 游戏 云计算 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 deepseek DeepSeek-R1 API接口 网络工程师 网络管理 软考 2024 2024年上半年 下午真题 答案 Deepseek Deepseek-R1 大模型 私有化部署 推理模型 RTSP xop RTP RTSPServer 推流 视频 物联网 ubuntu YOLO 网络结构图 php 开发语言 Ollama Qwen2.5-coder 离线部署 英语 macos windows conda 进程 操作系统 进程控制 Ubuntu CH340 单片机 嵌入式硬件 串口驱动 CH341 uart 485 llama 算法 opencv 自然语言处理 神经网络 语言模型 javascript 前端 chrome edge 模型联网 API CherryStudio debian PVE https centos node.js DNS jvm 虚拟机 人工智能 redis 深度学习 计算机视觉 卷积神经网络 数据库系统 vue.js spring boot nginx python MCP fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse android harmonyos typescript 鸿蒙 智能路由器 网络 外网访问 内网穿透 端口映射 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 tcp/ip 网络协议 ip协议 阿里云 网络安全 开发环境 ssh jellyfin nas cron crontab日志 pycharm ide 数据库 oracle 关系型 安全 分布式 游戏引擎 学习 ue4 着色器 ue5 虚幻 负载均衡 数据分析 机器学习 kubernetes prometheus grafana 云原生 笔记 C 环境变量 进程地址空间 outlook 错误代码2603 无网络连接 2603 策略模式 c++ c语言 pip 科技 ai 个人开发 zotero WebDAV 同步失败 代理模式 gnu fstab USB转串口 高级IO epoll 计算机外设 bug nlp ssh漏洞 ssh9.9p2 CVE-2025-23419 json gcc centos 7 IM即时通讯 QQ 微信 企业微信 剪切板对通 HTML FORMAT qt QT 5.12.12 QT开发环境 Ubuntu18.04 mcu matplotlib fonts-noto-cjk ubuntu 18.04 安装教程 vscode 电脑 mac 软件需求 华为 计算机网络 websocket django C# MQTTS 双向认证 emqx 大数据 spark hive pytorch transformer kafka 并查集 leetcode udp 本地环回 bind 媒体 eureka rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK 学习方法 经验分享 rust http apache 集成学习 集成测试 virtualenv AIGC dify ragflow react.js 前端面试题 持续部署 gitee 远程连接 rdp 实验 思科 嵌入式 linux驱动开发 arm开发 浪潮信息 AI服务器 windows 服务器安装 postman 测试工具 HarmonyOS Next DevEco Studio mysql adb .netcore vnc 后端 rust腐蚀 Dify onlyoffice html vSphere vCenter 软件定义数据中心 sddc vr 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 opengl CPU 内存 主板 电源 网卡 audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 ui 华为云 华为od 多线程 kylin 大语言模型 LLMs gateway Clion Nova ResharperC++引擎 Centos7 远程开发 burp suite 抓包 axure 富文本编辑器 Docker Hub docker pull 镜像源 daemon.json Linux tomcat Linux 维护模式 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 iftop 网络流量监控 自动化 Agent DeepSeek LLM CrewAI hadoop efficientVIT YOLOv8替换主干网络 TOLOv8 remote-ssh sublime text 编辑器 flutter Google pay Apple pay filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 asm dubbo 面试 jenkins AI编程 监控k8s集群 集群内prometheus MacOS录屏软件 软件测试 ddos web安全 聚类 ip spring cloud compose oceanbase 传统数据库升级 银行 Hyper-V WinRM TrustedHosts 多线程服务器 Linux网络编程 进程优先级 调度队列 进程切换 nftables 防火墙 ollama 开源 驱动开发 硬件工程 嵌入式实习 统信UOS 麒麟 bonding 链路聚合 numpy AI大模型 大模型技术 本地部署大模型 Cline VMware安装mocOS VMware macOS系统安装 华为认证 交换机 缓存 灵办AI 私有化 本地部署 shell 磁盘监控 github 实时音视频 实时互动 Alexnet SRS 流媒体 直播 pillow live555 rtsp rtp AI 大模型应用 c# Linux PID 架构 etcd 数据安全 RBAC 多层架构 解耦 oracle fusion oracle中间件 微信分享 Image wxopensdk svn vue3 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 openvpn server openvpn配置教程 centos安装openvpn 虚拟现实 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 uni-app 课程设计 maven iot 信息与通信 stm32项目 stm32 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn agi sql KingBase 向日葵 YOLOv8 NPU Atlas800 A300I pro asi_bench 计算生物学 生物信息学 生物信息 基因组 mariadb windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 spring 命名管道 客户端与服务端通信 rag ragflow 源码启动 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 Docker快速入门 unix ESP32 王者荣耀 智能手机 NAS Termux Samba 微服务 springcloud express p2p pygame mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 Cursor 网易邮箱大师 运维开发 迁移指南 qps 高并发 aws googlecloud yolov5 ESXi 软件工程 软件构建 进程信号 chatgpt AI-native Docker Desktop llm dell服务器 数据结构 链表 vim 指令 快捷键 旋转屏幕 自动操作 mongodb 部署 系统 黑苹果 openEuler Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 list 模拟实现 alias unalias 别名 devops springboot 客户端 java-ee 中间件 .net core .net 腾讯云 大模型部署 Invalid Host allowedHosts vue unity GameFramework HybridCLR Unity编辑器扩展 自动化工具 性能优化 权限 VMware安装Ubuntu Ubuntu安装k8s k8s xcode 职场和发展 sqlserver ssl 僵尸进程 rc.local 开机自启 systemd WebUI DeepSeek V3 前端框架 知识库 本地化部署 gpt Hive环境搭建 hive3环境 Hive远程模式 log4j edge浏览器 jupyter 豆瓣 追剧助手 迅雷 IPMI 互信 目标检测 rpc SSH Xterminal jmeter ip命令 新增网卡 新增IP 启动网卡 HCIE 数通 系统安全 ffmpeg 音视频 视频编解码 harmonyOS面试题 bash WSL2 Ubuntu22.04 虚拟化 开发人员主页 Linux的权限 flash-attention 报错 html5 firefox arm WLAN nfs rancher 机器人 漏洞 ios 爬虫 数据集 rabbitmq 电子信息 通信工程 毕业 tar Mermaid 可视化图表 自动化生成 云桌面 微软 AD域控 证书服务器 MS Materials Chatbox 银河麒麟 kylin v10 麒麟 v10 jar LDAP 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 gpu算力 intellij idea iis GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 创意 社区 jdk intellij-idea database VMware创建虚拟机 源码剖析 rtsp实现步骤 流媒体开发 vmware 卡死 自动化编程 ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 WSL2 上安装 Ubuntu 政务 分布式系统 监控运维 Prometheus Grafana ros2 moveit 机器人运动 CPU 使用率 系统监控工具 linux 命令 FTP 服务器 统信 国产操作系统 虚拟机安装 程序人生 protobuf 序列化和反序列化 安装 kind powerpoint webstorm 串口服务器 大模型入门 大模型教程 实战案例 游戏程序 主从复制 人工智能生成内容 数据挖掘 网络用户购物行为分析可视化平台 大数据毕业设计 1024程序员节 程序员 KylinV10 麒麟操作系统 Vmware burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 yum docker-compose docker compose Trae IDE AI 原生集成开发环境 Trae AI 压测 ECS camera Arduino openstack Xen KVM kali 共享文件夹 虚拟局域网 golang maxkb ARG 虚拟显示器 远程控制 安卓 cursor Kylin-Server 服务器安装 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos oneapi 大模型微调 GCC aarch64 编译安装 HPC 鸿蒙系统 程序员创富 flask 程序 编程 性能分析 Windsurf go milvus ros 话题通信 服务通信 centos-root /dev/mapper yum clean all df -h / du -sh tcpdump WSL win11 无法解析服务器的名称或地址 产品经理 microsoft 回显服务器 UDP的API使用 git gitea visual studio code gradle 3d 数学建模 RustDesk自建服务器 rustdesk服务器 docker rustdesk selenium 网络爬虫 perf 交互 seatunnel 腾讯云大模型知识引擎 毕设 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 UOS 统信操作系统 云原生开发 K8S k8s管理系统 TCP WebServer llama3 Chatglm 开源大模型 iBMC UltraISO cuda cudnn anaconda linux内核 Reactor 设计模式 C++ springsecurity6 oauth2 授权服务器 前后端分离 安卓模拟器 MacMini Mac 迷你主机 mini Apple vite YOLOv12 Dell R750XS lvm 磁盘挂载 磁盘分区 MCP server C/S 内网渗透 靶机渗透 HiCar CarLife+ CarPlay QT RK3588 温湿度数据上传到服务器 Arduino HTTP ubuntu20.04 ros1 Noetic 20.04 apt 安装 cpu 实时 使用 ipython 读写锁 Redis Desktop 远程工作 矩阵 GPU 微信小程序 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 arcgis 玩游戏 博客 SSH 密钥生成 SSH 公钥 私钥 生成 rclone AList webdav fnOS Cookie 工业4.0 ShenTong 国产化 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 keepalived 服务器部署 本地拉取打包 grub 版本升级 扩容 开机自启动 微信开放平台 微信公众平台 微信公众号配置 远程 命令 执行 sshpass 操作 ebpf uprobe neo4j 数据仓库 数据库开发 数据库架构 ROS2 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer 远程桌面 显示管理器 lightdm gdm 国产数据库 瀚高数据库 数据迁移 下载安装 蓝耘科技 元生代平台工作流 ComfyUI 代理 npm 飞牛nas fnos ruoyi 低代码 ArcTS 登录 ArcUI GridItem arkUI yum源切换 更换国内yum源 web Mac软件 bot Docker Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 safari 系统架构 minicom 串口调试工具 DevOps 软件交付 数据驱动 应用场景 nvidia 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 宝塔 Web服务器 多线程下载工具 网络编程 PYTHON 游戏机 宝塔面板无法访问 开机黑屏 大屏端 OpenManus SWAT 配置文件 服务管理 网络共享 Ubuntu 22.04 MySql 算家云 算力租赁 硬件 设备 PCI-Express shell脚本免交互 expect linux免交互 常用命令 文本命令 目录命令 python3.11 mq rocketmq 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 IIS Hosting Bundle .NET Framework vs2022 IIS服务器 IIS性能 日志监控 半虚拟化 硬件虚拟化 Hypervisor miniapp 真机调试 调试 debug 断点 网络API请求调试方法 能力提升 面试宝典 技术 IT信息化 Web应用服务器 micropython esp32 mqtt nuxt3 webrtc eclipse 热榜 图像处理 android studio ansible ollama下载加速 redhat 支付 微信支付 开放平台 服务器繁忙 openssl 密码学 gitlab EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 端口号 开放端口 访问列表 zabbix 小游戏 五子棋 跨域 MQTT mosquitto 消息队列 r语言 数据可视化 stable diffusion AI作画 服务器配置 pdf 办公自动化 pdf教程 服务器管理 宝塔面板 配置教程 网站管理 CLion NFS hibernate threejs 3D 区块链 okhttp kamailio sip VoIP 设置代理 实用教程 SenseVoice 大数据平台 postgresql docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 离线部署dify linux 命令 sed 命令 同步 备份 建站 云电竞 云电脑 todesk mysql离线安装 ubuntu22.04 mysql8.0 源码 毕业设计 Carla 智能驾驶 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 pyautogui 自动化任务管理 命令行 基础入门 混合开发 环境安装 JDK 可信计算技术 安全威胁分析 压力测试 zip unzip ukui 麒麟kylinos openeuler W5500 OLED u8g2 TCP服务器 监控 自动化运维 CNNs 图像分类 top Linux top top命令详解 top命令重点 top常用参数 网络穿透 功能测试 自动化测试 VPS AI写作 prompt nacos rustdesk 京东云 EMQX 通信协议 fd 文件描述符 小智 致远OA OA服务器 服务器磁盘扩容 Xinference RAGFlow 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 OD机试真题 华为OD机试真题 服务器能耗统计 DeepSeek行业应用 Heroku 网站部署 CORS chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 硬件架构 计算机 飞书 远程过程调用 Windows环境 dns 恒源云 samba css 信号处理 智能音箱 智能家居 IPMITOOL BMC 硬件管理 react next.js 部署next.js tcp ocr DocFlow asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 键盘 繁忙 解决办法 替代网站 汇总推荐 AI推理 安防软件 k8s集群资源管理 个人博客 飞牛NAS 飞牛OS MacBook Pro 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 AD域 邮件APP 免费软件 Open WebUI notepad 监控k8s 监控kubernetes ci/cd 代码规范 Linux24.04 deepin AISphereButler RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 具身智能 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 嵌入式系统开发 联网 easyconnect 匿名管道 软件卸载 系统清理 隐藏文件 隐藏目录 文件系统 管理器 通配符 浏览器自动化 大模型面经 大模型学习 AnythingLLM AnythingLLM安装 TrueLicense visual studio elasticsearch web3.py unity3d pyqt rime WebVM conda配置 conda镜像源 流水线 脚本式流水线 Kali Linux 黑客 渗透测试 信息收集 ufw 磁盘清理 跨平台 scapy 服务器主板 AI芯片 WebRTC 框架搭建 openwrt ux 智慧农业 开源鸿蒙 团队开发 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors 5G 3GPP 卫星通信 Python 聊天服务器 套接字 Socket 升级 CVE-2024-7347 vasp安装 AutoDL string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 无人机 游戏服务器 TrinityCore 魔兽世界 虚幻引擎 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 路径解析 其他 代码调试 ipdb adobe PX4 ROS 群晖 文件分享 wsl mamba Vmamba NPS 雨云服务器 雨云 MQTT协议 消息服务器 代码 视觉检测 dba 自动驾驶 RAGFLOW frp docker run 数据卷挂载 交互模式 交叉编译 Attention NLP code-server make命令 makefile文件 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 echarts 信息可视化 网页设计 open webui matlab 网络攻击模型 selete 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 scikit-learn 远程看看 远程协助 远程服务 银河麒麟操作系统 UEFI Legacy MBR GPT U盘安装操作系统 直播推流 sqlite3 rsyslog 机柜 1U 2U bcompare Beyond Compare telnet 远程登录 教程 环境搭建 Java Maven 三级等保 服务器审计日志备份 gpt-3 文心一言 环境配置 HistoryServer Spark YARN jobhistory n8n dity make 医疗APP开发 app开发 kernel wireshark 显示过滤器 ICMP Wireshark安装 linux环境变量 Mac内存不够用怎么办 图形化界面 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 序列化反序列化 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 React Next.js 开源框架 export import save load 迁移镜像 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 netlink libnl3 云耀服务器 强制清理 强制删除 mac废纸篓 bootstrap 拓扑图 cmake 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 搜索引擎 大文件秒传跨域报错cors RTMP 应用层 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 xml linux安装配置 线程 Ark-TS语言 孤岛惊魂4 P2P HDLC 一切皆文件 linux上传下载 windows日志 cmos 华为证书 HarmonyOS认证 华为证书考试 中兴光猫 换光猫 网络桥接 自己换光猫 TRAE opcua opcda KEPServer安装 工具分享 CosyVoice 域名服务 DHCP 符号链接 配置 RAID RAID技术 磁盘 存储 fork wait waitpid exit uv 单元测试 fpga开发 树莓派 VNC SSE kvm thingsboard sublime text3 重启 排查 系统重启 日志 原因 网卡的名称修改 eth0 ens33 excel nvm AI代码编辑器 Qualcomm WoS QNN AppBuilder wps 工具 Ubuntu共享文件夹 共享目录 Linux共享文件夹 visualstudio 换源 国内源 Debian ecmascript file server http server web server 深度求索 私域 知识图谱 系统开发 binder 车载系统 framework 源码环境 trae 状态管理的 UDP 服务器 Arduino RTOS 7z python2 ubuntu24.04 dash 正则表达式 armbian u-boot rnn 显卡驱动 双系统 kotlin iphone FunASR ASR EasyConnect nextjs reactjs 镜像下载 freebsd 流式接口 curl wget 金融 ftp su sudo sudo原理 su切换 Wi-Fi 硅基流动 ChatBox 目标跟踪 OpenVINO 推理应用 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 FTP服务器 执法记录仪 智能安全帽 smarteye Ubuntu20.04 GLIBC 2.35 glibc 分析解读 产测工具框架 IMX6ULL 管理框架 iperf3 带宽测试 mybatis C语言 langchain deep learning ssrf 失效的访问控制 MNN Qwen JAVA SSL证书 HP Anyware yolov8 开发 深度优先 图论 并集查找 换根法 树上倍增 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 CentOS Stream CentOS xrdp lio-sam SLAM 蓝桥杯 小艺 Pura X odoo 服务器动作 Server action deepseek-r1 大模型本地部署 gaussdb 版本 llama.cpp 环境迁移 网络文件系统 .net mvc断点续传 grep 多进程 Node-Red 编程工具 流编程 服务器扩容没有扩容成功 生活 测试用例 桌面环境 playbook 剧本 工作流 workflow 图片增强 增强数据 firewalld 银河麒麟服务器操作系统 系统激活 视频平台 录像 视频转发 性能测试 视频流 安全架构 输入法 av1 电视盒子 机顶盒ROM 魔百盒刷机 ArkUI ArkTS 移动端开发 termux clickhouse diskgenius 社交电子 AD 域管理 MDK 嵌入式开发工具 论文笔记 vscode 1.86 网站搭建 serv00 sonoma 自动更新 直流充电桩 充电桩 WireGuard 异地组网 easyui 运维监控 xshell termius iterm2 游戏开发 SEO Linux的基础指令 负载测试 小智AI服务端 xiaozhi TTS 分子对接 autodock mgltools PDB PubChem 历史版本 下载 NAT转发 NAT Server etl 音乐服务器 Navidrome 音流 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 banner beautifulsoup chrome devtools chromedriver PyQt PySide6 DeepSeek r1 hugo Netty 即时通信 NIO 健康医疗 HTTP 服务器控制 ESP32 DeepSeek EVE-NG 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS 毕昇JDK 强化学习 单例模式 x64 SIGSEGV xmm0 软件 HarmonyOS OpenHarmony 免费域名 域名解析 llamafactory 微调 c/c++ 串口 弹性服务器 qt5 客户端开发 css3 边缘计算 高效I/O xpath定位元素 pppoe radius sqlite 沙盒 bat 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 pgpool qt项目 qt项目实战 qt教程 图形渲染 业界资讯 模拟退火算法 田俊楠 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP System V共享内存 进程通信 相机 sdkman 用户缓冲区 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 新盘添加 partedUtil docker部署Python cocoapods pyside6 界面 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 ueditor导入word ueditor导入pdf ueditor导入ppt openjdk macbook crosstool-ng NVML nvidia-smi 管道 prometheus数据采集 prometheus数据模型 prometheus特点 银河麒麟高级服务器 外接硬盘 Kylin UOS1070e ShapeFile GeoJSON Nginx WINCC 代码托管服务 Kali 渗透 k8s部署 MySQL8.0 高可用集群(1主2从) 软链接 硬链接 论文阅读 chfs ubuntu 16.04 SSH 服务 SSH Server OpenSSH Server deepseak 豆包 KIMI 腾讯元宝 cnn DenseNet MobaXterm 文件传输 Nuxt.js webgl qemu libvirt 内网服务器 内网代理 内网通信 embedding minio 智能电视 考研 ping++ 在线office Xshell LVM lvresize 磁盘扩容 pvcreate 推荐算法 考试 Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 网络原理 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 ruby 电视剧收视率分析与可视化平台 cd 目录切换 uniapp web3 trea idea 玩机技巧 软件分享 软件图标 ubuntu24 vivado24 CUPS 打印机 Qt5 DIFY apt 昇腾 大模型训练/推理 推理问题 mindie docker命令大全 virtualbox tensorflow wpf Ubuntu Server Ubuntu 22.04.5 移动云 CDN 鲲鹏 端口测试 iTerm2 nohup 异步执行 env 变量 XCC Lenovo 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 蓝牙 Helm k8s集群 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 fiddler elk IO 代理服务器 Docker Compose wsgiref Web 服务器网关接口 zookeeper Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 配置原理 大大通 第三代半导体 碳化硅 deepseek r1 全文检索 图搜索算法 实习 Windows ai工具 java-rocketmq Jellyfin ldap LORA 阻塞队列 生产者消费者模型 服务器崩坏原因 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 反向代理 黑客技术 显示器 URL PPI String Cytoscape CytoHubba kubeless 华为机试 内网环境 h.264 增强现实 沉浸式体验 技术实现 案例分析 AR 稳定性 看门狗 Typore 华为OD 可以组成网络的服务器 GoogLeNet cpp-httplib c opensearch helm MI300x firewall mysql安装报错 windows拒绝安装 Zoertier 内网组网 镜像 npu 金仓数据库 2025 征文 数据库平替用金仓 open Euler dde Linux权限 权限命令 特殊权限 USB网络共享 pyicu zerotier sysctl.conf vm.nr_hugepages 浏览器开发 AI浏览器 云服务 MAC SecureCRT ollama api ollama外网访问 Radius token sas 崖山数据库 YashanDB db tidb 大版本升 升级Ubuntu系统 物联网开发 Isaac Sim 虚拟仿真 RAG 检索增强生成 文档解析 大模型垂直应用 saltstack 技能大赛 Ardupilot vpn 服务器部署ai模型 Anolis nginx安装 linux插件下载 模拟器 swoole ArkTs 阿里云ECS laravel 免密 公钥 私钥 Office Claude eNSP 网络规划 VLAN 企业网络 无桌面 做raid 装系统 risc-v copilot VSCode Apache Beam 批流统一 案例展示 数据分区 容错机制 网页服务器 web服务器 基础环境 initramfs Linux内核 Grub Linux Vim ELF加载 searxng 联想开天P90Z装win10 ajax 多个客户端访问 IO多路复用 TCP相关API VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 抗锯齿 hosts EMUI 回退 降级 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? can 线程池 网工 充电桩平台 充电桩开源平台 宕机切换 服务器宕机 less cfssl 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 idm nac 802.1 portal 互联网医院 单一职责原则 vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 GRUB引导 Linux技巧 DOIT 四博智联 Unity Dedicated Server Host Client 无头主机 Playwright IMM 数据管理 数据治理 数据编织 数据虚拟化 数码 联机 僵尸毁灭工程 游戏联机 开服 ssh远程登录 iDRAC R720xd powerbi 信号 MAVROS 四旋翼无人机 HarmonyOS NEXT 原生鸿蒙 ceph ftp服务 文件上传 相差8小时 UTC 时间 日志分析 系统取证 netty lb 协议 iventoy VmWare OpenEuler 信创 信创终端 中科方德 开源软件 自定义客户端 SAS 空间 查错 dock 加速 yaml Ultralytics 可视化 XFS xfs文件系统损坏 I_O error es wsl2 GIS 遥感 WebGIS vmamba wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 实时内核 nohup后台启动 技术共享 csrutil mac恢复模式进入方法 恢复模式 容器技术 我的世界 我的世界联机 jina IPv4 子网掩码 公网IP 私有IP 内核 glm4 本地部署AI大模型 DBeaver kerberos 安装MySQL vscode1.86 1.86版本 ssh远程连接 jetty undertow composer 计算机科学与技术 底层实现 SysBench 基准测试 ecm bpm LLM Web APP Streamlit ISO镜像作为本地源 k8s二次开发 集群管理 seleium 冯诺依曼体系 极限编程 多产物 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 es6 qt6.3 g726 Reactor反应堆 iNode Macos 语音识别 Minecraft Dell HPE 联想 浪潮 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口服务器 Ubuntu 24.04.1 轻量级服务器 宠物 免费学习 宠物领养 宠物平台 dns是什么 如何设置电脑dns dns应该如何设置 笔灵AI AI工具 自学笔记 小米 澎湃OS Android 软负载 聊天室 AI agent xfce perl 思科模拟器 Cisco ubuntu24.04.1 NLP模型 fast VPN wireguard 蓝桥杯C++组 端口 查看 ss chromium dpi Claude Desktop Claude MCP Windows Cli MCP muduo X11 Xming 飞牛 VR手套 数据手套 动捕手套 动捕数据手套 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 v10 H3C 算力 授时服务 北斗授时 计算虚拟化 弹性裸金属 显卡驱动持久化 GPU持久化 Qwen2.5-VL vllm VS Code word IMX317 MIPI H265 VCU nosql hexo rpa 区块链项目 服务网格 istio 7-zip Linux find grep 钉钉 IPv6 IPv6测试 IPv6测速 IPv6检测 IPv6查询 终端工具 远程工具 win服务器架设 windows server 语法 我的世界服务器搭建 minecraft AzureDataStudio 合成模型 扩散模型 图像生成 抓包工具 查询数据库服务IP地址 SQL Server 分布式训练 设备树 行情服务器 股票交易 速度慢 切换 股票量化接口 股票API接口 autoware 鸿蒙开发 移动开发 智能合约 哈希算法 sequoiaDB 捆绑 链接 谷歌浏览器 youtube google gmail g++ g++13 HAProxy IP配置 netplan 根服务器 企业网络规划 华为eNSP 存储维护 NetApp存储 EMC存储 regedit 开机启动 用户管理 服务器ssl异常解决 GeneCards OMIM TTD 火绒安全 大模型推理 需求分析 规格说明书 SystemV ranger MySQL8.0 servlet 北亚数据恢复 oracle数据恢复 LInux 移动魔百盒 mcp服务器 client close Sealos Headless Linux 程序化交易 量化交易 高频交易 打不开xxx软件 无法检查其是否包含恶意软件 arkTs flink SSL 域名 skynet 影刀 #影刀RPA# 分布式账本 信任链 共识算法 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 junit VGG网络 卷积层 池化层 Pyppeteer 项目部署到linux服务器 项目部署过程 超融合 figma 安全漏洞 信息安全 桌面快捷方式 big data deekseek retry 重试机制 问题解决 动态规划 查看显卡进程 fuser ArtTS navicat SVN Server tortoise svn 烟花代码 烟花 元旦 性能调优 安全代理 本地知识库部署 DeepSeek R1 模型 IO模型 僵尸世界大战 游戏服务器搭建 进程间通信 Linux环境 Python基础 Python教程 Python技巧 搭建个人相关服务器 Obsidian Dataview proxy模式 yashandb MacOS rtc mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 docker desktop 架构与原理 gunicorn tailscale derp derper 中转 autodl triton 模型分析 多路转接 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 输入系统 TCP协议 嵌入式Linux IPC 欧标 OCPP 软件开发 动静态库 lua java-zookeeper 智能体 autogen openai coze 多端开发 智慧分发 应用生态 鸿蒙OS 子系统 锁屏不生效 NFC 近场通讯 智能门锁 项目部署 智能体开发 ubuntu安装 linux入门小白 midjourney MVS 海康威视相机 sentinel GRE 元服务 应用上架 佛山戴尔服务器维修 佛山三水服务器维修 OpenSSH linuxdeployqt 打包部署程序 appimagetool c/s Spring Security AimRT 加解密 Yakit yaklang 干货分享 黑客工具 密码爆破 线性代数 电商平台 massa sui aptos sei 终端 服务器时间 react native 带外管理 对比 meld DiffMerge 端口聚合 windows11 达梦 DM8 风扇控制软件 Erlang OTP gen_server 热代码交换 事务语义 resolv.conf Bug解决 Qt platform OpenCV 音乐库 postgres Dify重启后重新初始化 AI员工 xss Echarts图表 折线图 柱状图 异步动态数据 可视化效果 localhost image 金仓数据库概述 金仓数据库的产品优化提案 deployment daemonset statefulset cronjob AI Agent 字节智能运维 whistle 内存管理 状态模式 post.io 企业邮箱 搭建邮箱 pthread element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 js archlinux kde plasma Webserver 异步 解决方案 飞腾处理器 机械臂 李心怡 solidworks安装 ABAP 三次握手 Alist mount 挂载 网盘 海康 搜狗输入法 中文输入法 可用性测试 IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 mac设置host Python 视频爬取教程 Python 视频爬取 Python 视频教程 脚本 NVM Node Yarn PM2 零售 yum换源 ardunio BLE 源代码 支持向量机 粘包问题 Qwen3 qwen3 32b GPU训练 文件存储服务器组件 logstash 西门子PLC 通讯 商用密码产品体系 框架 星河版 设计规范 IDEA comfyui comfyui教程 免费 源代码管理 Unity插件 数字证书 签署证书 跨域请求 webview 流量运营 Logstash 日志采集 服务器正确解析请求体 RDP 券商 股票交易接口api 类型 特点 接口优化 macOS systemctl 软考设计师 中级设计师 SQL 软件设计师 卸载 列表 hdc 鸿蒙NEXT UDP rsync Trae叒更新了? Qt QModbus brew node client-go 计算机系统 静态IP linux子系统 忘记密码 chatbox mvc solr 物理地址 页表 虚拟地址 #STC8 #STM32 计算机学习路线 编程语言选择 mybase watchtower 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 向量数据库 安装部署 milvus安装 Masshunter 质谱采集分析软件 使用教程 科研软件 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia AWS lrzsz 华为昇腾910b3 Charles paddle 材料工程 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 可执行程序 MinIO NVIDIA 命令模式 机架式服务器 1U工控机 国产工控机 RK3568 docker search vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 火山引擎 Putty 花生壳 UFW caddy qwen2vl android-studio 知行EDI 电子数据交换 知行之桥 EDI CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 gru authing d3d12 Linux的基础开发工具 VM虚拟机 pythonai PlaywrightMCP easyTier 组网 线程同步 线程互斥 条件变量 homeassistant