最新资讯

  • 对于C++中string的详细介绍

对于C++中string的详细介绍

2026-02-04 21:14:04 栏目:最新资讯 4 阅读

开篇介绍:

hello 大家,在前面几篇博客中,我们算是把C++中的入门基础+类和对象+模版初阶成功拿下。

那么,接下来我们就要进入C++中真正的重点中了,STL的使用,那么呢,其实也就是直接使用        C++中所提供的现成的数据结构,比如我们今天要讲的string类。

那么string类呀,是一个非常重要也非常好使的一个数据结构,那么接下来,就让我们来详细了解一下C++中的string类。

string的介绍:

在 C++ 中,std::string 是标准库(STL)提供的字符串类,用于高效管理和操作字符序列。它封装了动态字符数组的逻辑,自动处理内存分配与释放,是 C 语言风格字符数组(char[])的现代化替代方案。以下从定义、特性、操作到高级用法,全面详解 std::string

一、基本定义与头文件

std::string 位于  头文件中,属于 std 命名空间,其本质是 std::basic_string 的特化版本(针对单字节字符,如 ASCII、UTF-8)。类似的还有宽字符版本:

  • std::wstringbasic_string):用于宽字符(如 Unicode 16/32 位);
  • std::u16string(C++11,basic_string):UTF-16 编码;
  • std::u32string(C++11,basic_string):UTF-32 编码。

日常开发中最常用的是 std::string(单字节字符),使用前需包含头文件并声明命名空间:

#include 
using namespace std;  // 或显式使用 std::string

二、核心特性

  1. 可变性:字符串内容可直接修改(区别于 Python str、Java String 的不可变性)。
  2. 动态内存管理:自动扩容 / 缩容,无需手动分配 / 释放内存(避免 C 语言 char[] 的内存泄漏风险)。
  3. 与 STL 兼容:支持迭代器、算法(如 std::reversestd::find),可作为容器使用。
  4. 编码无关性:仅管理字节序列,不直接处理编码(需结合外部逻辑处理 UTF-8 等多字节编码)。

三、初始化与构造

std::string 提供多种构造方式,覆盖不同场景:

构造方式示例代码说明
默认构造string s;空字符串(长度 0,容量可能为 0 或默认值)。
C 字符串初始化string s("hello"); 或 string s = "hello";用 C 风格字符串(const char*)初始化。
复制构造string s1("abc"); string s2(s1); 或 string s3 = s1;复制已有字符串。
截取 C 字符串前 n 个字符string s("hello", 3); // 结果:"hel"取前 3 个字符(超出原长度则取全部)。
n 个重复字符string s(5, 'a'); // 结果:"aaaaa"用 5 个 'a' 初始化。
范围初始化(迭代器)string s1("hello"); string s2(s1.begin(), s1.begin() + 3); // "hel"用另一个字符串的迭代器范围初始化。
移动构造(C++11)string s1("hello"); string s2(std::move(s1)); //s1 变为空,s2 为 "hello"转移资源,避免复制(高效)。

四、基本操作(元素访问与长度)

1. 元素访问

std::string 支持通过索引或迭代器访问字符,常用方式:

  • operator[]:直接访问索引位置的字符(不检查越界,越界行为未定义)。
  • at(size_t pos):访问索引位置的字符(检查越界,越界抛出 std::out_of_range 异常)。
  • front() / back():访问第一个 / 最后一个字符(C++11,空字符串调用会导致未定义行为)。
  • 迭代器begin() / end()(正向迭代)、rbegin() / rend()(反向迭代)。

示例:

string s = "hello";
cout << s[1] << endl;      // 'e'(无越界检查)
cout << s.at(2) << endl;   // 'l'(有越界检查)
cout << s.front() << endl; // 'h'
cout << s.back() << endl;  // 'o'

// 迭代器遍历
for (auto it = s.begin(); it != s.end(); ++it) {
    cout << *it;  // 输出 "hello"
}

2. 长度与容量

std::string 区分 长度(实际字符数) 和 容量(已分配的内存可容纳的最大字符数,不含终止符 

  • size() / length():返回当前字符串长度(两者等价,length() 是历史遗留,建议用 size())。
  • capacity():返回当前容量(预分配的内存大小,避免频繁扩容)。
  • empty():判断是否为空字符串(size() == 0 时返回 true)。
  • reserve(size_t n):预分配至少能容纳 n 个字符的内存(仅增大容量,不改变长度)。
  • shrink_to_fit()(C++11):将容量缩减至与长度一致(释放多余内存,可能触发重分配)。

示例:

string s = "hello";
cout << s.size() << endl;    // 5(实际字符数)
cout << s.capacity() << endl; // 可能为 5 或更大(取决于编译器实现)

s.reserve(10);  // 预分配至少 10 个字符的空间
cout << s.capacity() << endl; // ≥10(容量增大,长度仍为 5)

s.shrink_to_fit();
cout << s.capacity() << endl; // 5(容量缩减至与长度一致)

五、修改操作(增删改)

std::string 支持灵活的修改,核心方法如下:

1. 尾部添加

  • push_back(char c):在尾部添加单个字符。
  • append(...):在尾部添加字符串(支持多种参数,如 const char*std::string、子串、重复字符等)。
  • operator+=:简化拼接(支持 charconst char*std::string)。

示例:

string s = "abc";

s.push_back('d');          // s = "abcd"
s.append("ef");            // s = "abcdef"
s.append(2, 'g');          // s = "abcdefgg"
s += "h";                  // s = "abcdefggh"

2. 插入字符 / 字符串

insert(pos, ...):在指定位置 pos 插入内容(pos 为索引,从 0 开始),支持插入:

  • 单个字符;
  • C 字符串或 std::string
  • 子串(指定起始位置和长度);
  • 迭代器范围。

示例:

string s = "abc";

s.insert(1, "xx");         // 在索引 1 插入 "xx" → "axxcb"
s.insert(3, 2, 'y');       // 在索引 3 插入 2 个 'y' → "axxyycb"

3. 删除字符 / 字符串

  • erase(pos, len):从位置 pos 开始删除 len 个字符(len 省略时删除至结尾)。
  • pop_back()(C++11):删除最后一个字符(等价于 erase(size()-1, 1))。
  • clear():清空字符串(长度变为 0,容量可能保留)。

示例:

string s = "abcdef";

s.erase(2, 2);   // 从索引 2 删 2 个字符 → "abef"
s.pop_back();     // 删除最后一个字符 → "abe"
s.clear();        // 清空 → ""(size=0,capacity 可能不变)

4. 替换子串

replace(pos, len, new_str):从位置 pos 开始,删除 len 个字符,替换为 new_strnew_str 可以是 const char*std::string、重复字符等)。

示例:

string s = "hello world";

s.replace(6, 5, "there");  // 从索引 6 删 5 个字符("world"),替换为 "there" → "hello there"
s.replace(0, 5, 3, 'x');   // 从索引 0 删 5 个字符("hello"),替换为 3 个 'x' → "xxxt here"

六、字符串拼接与比较

1. 拼接

除了 append() 和 operator+=,还可直接用 operator+ 拼接两个字符串(返回新字符串,原字符串不变):

string s1 = "hello", s2 = "world";
string s3 = s1 + " " + s2;  // s3 = "hello world"

2. 比较

std::string 支持两种比较方式:

  • 关系运算符==!=<><=>=(按字典序比较,同 C 语言 strcmp)。
  • compare(...) 方法:返回整数(0 表示相等,正数表示当前字符串更大,负数表示更小),支持比较子串。

示例:

string s1 = "apple", s2 = "banana";

cout << (s1 < s2) << endl;  // true('a' < 'b')
cout << s1.compare(s2) << endl;  // 负数(s1 < s2)
cout << s1.compare(0, 3, s2, 0, 3) << endl;  // 比较 s1[0..2]("app") 和 s2[0..2]("ban") → 负数

七、查找与子串

1. 查找子串

std::string 提供一系列查找方法,返回子串首次出现的索引(未找到返回 std::string::npos,一个静态常量,表示无效索引):

方法功能示例(s = "ababa")
find(str, pos)从 pos 开始查找 str 首次出现位置s.find("aba") → 0(从 0 开始找)
rfind(str, pos)从 pos 开始反向查找 str 末次出现位置s.rfind("aba") → 2(从末尾反向找)
find_first_of(str)查找 str 中任一字符首次出现位置s.find_first_of("xyzab") → 0(找 'a')
find_last_of(str)查找 str 中任一字符末次出现位置s.find_last_of("ab") → 4(最后一个 'a')
find_first_not_of(str)查找首个不在 str 中的字符位置s.find_first_not_of("ab") → npos(全是 'a'/'b')

示例:

string s = "hello world";
size_t pos = s.find("world");
if (pos != string::npos) {
    cout << "找到,位置:" << pos << endl;  // 输出 6
}

2. 截取子串

substr(pos, len):从位置 pos 开始截取 len 个字符(len 省略时截取至结尾,pos 越界会抛出异常)。

示例:

string s = "hello world";
string sub1 = s.substr(6);    // 从 6 开始截取至结尾 → "world"
string sub2 = s.substr(0, 5); // 从 0 开始截取 5 个字符 → "hello"

八、与 C 风格字符串的交互

C++ 中部分场景(如 C 库函数)需要 C 风格字符串(const char*),std::string 提供两种转换方法:

  • c_str():返回指向字符串的 const char* 指针(以  结尾,与 C 兼容)。
  • data():C++11 前返回 const char*(可能不含 ),C++11 后与 c_str() 等价(保证以  结尾)。

注意:指针仅在字符串未被修改且未析构时有效(修改字符串会导致指针失效)。

示例:

string s = "hello";
const char* cstr = s.c_str();  // 转换为 C 风格字符串
printf("%s
", cstr);          // 输出 "hello"(C 库函数使用)

九、高级用法

1. 迭代器与 STL 算法

std::string 支持迭代器,可直接使用 STL 算法(如 std::reversestd::sort):

#include   // 包含算法库

string s = "hello";
reverse(s.begin(), s.end());  // 反转字符串 → "olleh"

sort(s.begin(), s.end());     // 排序 → "ehllo"

2. 字符串与数值转换

C++11 起提供了字符串与数值的转换函数(位于  头文件):

  • 字符串转数值:stoi(int)、stol(long)、stoll(long long)、stof(float)、stod(double)等。
  • 数值转字符串:to_string(支持所有基本数值类型)。

示例

// 字符串转数值
string s1 = "123";
int num1 = stoi(s1);  // 123

string s2 = "3.14";
double num2 = stod(s2);  // 3.14

// 数值转字符串
int num3 = 456;
string s3 = to_string(num3);  // "456"

3. 原始字符串字面量(C++11)

用 R"(...)" 定义原始字符串(忽略转义字符 ),适合路径、正则表达式等场景:

string path = R"(C:Users
ameile.txt)";  // 无需转义,直接表示 "C:Users
ameile.txt"

十、注意事项

  1. 迭代器失效:修改字符串(如 inserterasereserve 触发扩容)可能导致迭代器、指针、引用失效,需重新获取。

    string s = "abc";
    auto it = s.begin();
    s.push_back('d');  // 若触发扩容,it 失效
    // *it 行为未定义!需重新获取:it = s.begin();
    
  2. 容量与性能:频繁拼接字符串时,提前用 reserve(n) 预分配容量可避免多次扩容(每次扩容可能复制整个字符串,耗时)。

  3. 空字符串处理:对空字符串调用 front()back()pop_back() 会导致未定义行为,需先用 empty() 判断。

  4. 多线程安全std::string 不是线程安全的,多线程读写需加锁。

  5. 编码问题std::string 仅存储字节序列,若处理 UTF-8 等多字节编码(如中文、emoji),需注意:

    • 单个字符可能占多个字节(如 ' 中 ' 占 3 字节 UTF-8),size() 返回的是字节数而非字符数。
    • 直接用 [] 访问可能获取到半个字符(导致乱码),需结合编码库(如 ICU)处理。

总结

std::string 是 C++ 中处理字符串的首选工具,它结合了 C 风格字符数组的灵活性与 STL 的封装性,提供了丰富的操作接口,同时自动管理内存,大幅降低了出错风险。掌握其初始化、修改、查找等核心操作,以及与 C 风格字符串的交互,能高效处理文本数据。

示例代码:

那么我给大家一些关于string里面的一些比较常用重要的使用样例代码:

#include
#include
using namespace std;

//string
//需要注意,string是个类
//里面存放着动态数组,但是数组里面存储的是字符类型
//class String
//{
//public:
//	//成员函数
//private:
//	char* _str;//动态数组
//	int _size;
//	int _capacity;
//};

//string是在std里面的
//std::string;

void teststringconstruct()
{
	//default (1) string();无参构造函数
	std::string str1;//调用string类中的无参构造函数

	cout << str1 << endl;

	//from c - string(4) string(const char* s);
	string str2("hello world!");//调用string类中的有参构造函数
    //括号里面要加双引号,然后再放我们要存储进去的数据

	//copy(2) string(const string & str);拷贝构造函数
	string str3 = str2;
	cout << str3 << endl;

	//fill(6) string(size_t n, char c);使用n个c字符去将string数组填充
	string str4(5, 'h');//单字符用单引号
	cout << str4 << endl;

	//substring(3) string(const string & str, size_t pos, size_t len = npos);
	//将str的第pos个位置往后一个位置开始,将len个字符填充到创建的新str中
	//string::npos指42亿巴拉巴拉,并不是指-1
	//即使我们输入的len超出了str的数据长度,编译器也会自动到字符串终止符停下
	string str5(str2, 6, 5);
	string str6(str2, 6, string::npos);
	string str7("hello world", 6, 5);
	cout << str5 << endl;
	cout << str6 << endl;
	cout << str7 << endl;

	//from sequence(5) string(const char* s, size_t n);
	//从s的第一个数据开始到第n个数据结束,这之间的数据都丢到新创建的str中
	string str8("hello world", 5);//但是要注意,此时前面的就不是string类型的了,而是char*类型
	//也就代表着我们不能传string类变量进去
	cout << str8 << endl;

	//需要注意的是,string中也有对<<和>>这个操作符进行重载
	//所以我们是可以直接通过<<去对一个string类变量输入数据
	//同时我们上面能直接就将一个string类变量的数据都输出
	//也是依靠着string类中对<<的重载
	//可以参考日期类中对<<和>>的运算符重载函数
	string str9;//先创建类变量,然后再去对这个变量进行数据输入
	cin >> str9;
	cout << str9 << endl;

	//string类中还有一个很牛波一的
	//就是对[]的运算符重载
	//我们可以直接通过string类变量[n],去访问类变量中下标为n的数据
	//数组都是从0开始存储数据的哦
	string str10 = "hello world";//拷贝构造函数
	cout << str10[0] << str10[5] << str10[10] << endl;
	//         h           ' '          d
	//然后就是要知道它[]运算符重载函数返回的是引用,所以可以直接修改
	str10[0] = 'q';
	cout << str10 << endl;

	//string类的析构函数就不需要我们自己调用了
	//编译器会自动调用
	//~string();
}

void teststringiterator()
{
	std::string str1("hello world");

	//第一种遍历字符串方式:for循环
	//需要注意的是,在string类中,提供了size()这个函数用于返回字符串数组中数据的个数
	//所以我们可以直接借助size()这个函数去获取字符串数组中数据的个数
	for (int i = 0; i < str1.size(); i++)
	{
		cout << str1[i] << " ";
	}

	cout << endl;

	//在C++中,还提供了迭代器的一个功能
	//应用这个迭代器,我们可以实现高效的遍历数组、字符串等等数据结构
	//迭代器可以看作是一种 "指针",指向容器中的某个元素
	//通过迭代器可以读写它所指向的元素
	//迭代器可以移动,从而指向容器中的其他元素
	//不同容器有不同类型的迭代器,具有不同的功能特性


	//使用格式就是类::iterator 创建的变量名字 = 类变量名.某个成员函数
	//那么对于最后的成员函数是有不同的函数对应不同的功能
	//比如begin()就会返回指向字符串的第一个元素,类似str[0]
	//而end()则是指向字符串中最后一个有效数据的后面一个,类似我们实现顺序表时的size
	//begin()和end()的返回值都是指针哦,所以我们可以直接用it这个指针变量接收

	string::iterator it = str1.begin();
	//其实it就是一个指针变量,就这么简单
	while (it != str1.end())
	{
		cout << *it << " ";//解引用迭代器 it,输出它所指向的字符,然后输出一个空格。
		it++;
	}

	cout << endl;

	//那么也有反向迭代器,即从反方向开始的
	//叫做reverse_iterator 
	//rbegin() 返回的反向迭代器指向容器的最后一个元素(即正向迭代器 end() 的前一个位置)。
	//rend() 返回的反向迭代器指向容器第一个元素的前一个位置(即正向迭代器 begin() 的前一个位置)。	//依旧是使用++
	//rbegin()和rend()的返回值都是指针哦,所以我们可以直接用it这个指针变量接收
	//也是使用++
	string::reverse_iterator rit = str1.rbegin();
	while (rit != str1.rend())
	{
		cout << *rit << " ";//解引用
		rit++;
		//反向迭代器的 ++ 操作是向字符串起始方向移动(与正向迭代器的 -- 效果相同),
		//符合反向遍历的逻辑。
	}

	cout << endl;

	//要注意,上面说的两种迭代器,都是可以对数据进行修改的
	//eg:
	string str2("good moring");
	string::iterator it1 = str2.begin();
	cout << "小写转为大写:";
	while (it1 != str2.end())
	{
		*it1 -= 32;//修改元素,从小写转换为大写
		cout << *it1 << " ";
		++it1;
	}
	//修改了之后可就是修改了
	cout << endl;

	string::reverse_iterator rit1 = str2.rbegin();
	cout << "大写转为小写:";
	while (rit1 != str2.rend())
	{
		*rit1 += 32;//修改元素,从大写转为小写
		cout << *rit1 << " ";
		++rit1;
	}

	cout << endl;

	//那么其实还有不可以修改的迭代器,也就是只能读不能修改
	//是const_iterator和const_reverse_iterator
	//用法和上面一样
	
	//const_iterator
	string str3("good noon");
	string::const_iterator cit = str3.cbegin();
	while (cit != str3.cend())
	{
		cout << *cit << " ";//解引用迭代器 it,输出它所指向的字符,然后输出一个空格。
		cit++;
	}

	cout << endl;

	//const_reverse_iterator
	string::const_reverse_iterator crit = str3.crbegin();
	while (crit != str3.crend())
	{
		cout << *crit << " ";//解引用迭代器 it,输出它所指向的字符,然后输出一个空格。
		crit++;
	}

	cout << endl;
}

void teststringauto()
{
	//C++11 里的auto就是让编译器 "自动推断变量类型",不用我们手动写类型了,特别方便。
	auto a = 10;//auto==int
	//其实就是我们可以把auto当作是一个数据类型,
	//然后就像平时创建数据类型变量一样去创建auto类型变量
	//那么编译器会根据我们给变量的值自动识别个变量是什么类型的
	//然后把auto自动替换为其所识别到的类型
	//那么这也就是说明使用auto的时候,必须要初始化
	//说白了就是像模版中typename type1

	auto ch = 'a';//ayto==char

	auto f = 10.10;//auto==float

	//当在同一行声明多个变量时,这些变量必须是相同的类型,否则编译器将会报错,
	//因为编译器实际只对第一个类型进行推导,然后用推导出来的类型定义其他变量。

	auto a1 = 10, b1 = 20, c1 = 30;

	//auto不能直接用来声明数组
	//auto arr[100] = { 0 };//这种写法是错的

	//范围for
	//对于一个有范围的集合而言,由程序员来说明循环的范围是多余的,有时候还会容易犯错误。
	//因此C++11中引入了基于范围的for循环。
	//for循环后的括号由冒号“ :”分为两部分:第一部分是范围内用于迭代的变量,
	//第二部分则表示被迭代的范围,自动迭代,自动取数据,自动判断结束。
	//范围for可以作用到数组和容器对象上进行遍历
	//范围for的底层很简单,容器遍历实际就是替换为迭代器,这个从汇编层也可以看到。

	//其实就是使用for,然后:前面放类型加变量
	//:后面放要进行循环的数据
	int arr[5] = { 1,2,3,4,5 };
	for (auto i : arr)
	{
		cout << i << " ";
	}
	//如上面的例子
	//其实i就相当于既是之前for循环的int i
	//又相当于是arr[i],编译器会自动判断arr到哪里结束
	//也就是要进行几次循环,不需要我们再去手动指定
	//那么将i的类型设置为auto的好处就是可以让编译器去自己分辨auto要是什么类型的
	cout << endl;
	for (int i = 0; i < 5; i++)
	{
		cout << arr[i] << " ";
	}

	cout << endl;
	string str1("good afternoon");
	for (auto ch : str1)
	{
		cout << ch << " ";
	}
	cout << endl;
	for (int i = 0; i < str1.size(); i++)
	{
		cout << str1[i] << " ";
	}
	
	//真的是嘎嘎好使,嘎嘎好使
}

void  teststringpush()
{
	std::string str1("hello world");

	str1.push_back(' ');//尾插数据进已经创建的字符串数组
	str1.push_back('a');//尾插数据进已经创建的字符串数组
	cout << str1 << endl;

	//同样的,append也可以指定插入的字符串中字符个数
	str1.append(" hello world", 3);
	cout << str1 << endl;

	//不过一般来说,我们都是用string中提供的+=运算符重载函数来尾插数据
	string str2("xxxxxxx");
	str2 += 'a';
	cout << str2 << endl;
	str2 += "bbbbbb";
	cout << str2 << endl;

	//还有就是+运算符重载函数:
	string str3;//创建空字符串
	str3 = str2 + " nihao";//用一个新的字符串接收两个字符串相加的结果
	//上面的str2和“nihao”的位置也可以互换
	cout << str3 << endl;

	//assign就是将原字符串的内容用新的内容进行替换
	//不重要,略

	//insert,头插
	string str4 = "kkkkk";
	str4.insert(str4.begin(), 'm');//头插到第一个数据
	cout << str4 << endl;
	str4.insert(2, "aaa");//从下标为2的位置开始插入“aaa”
	cout << str4 << endl;

	//erase,除去字符串中从一个位置到另一个位置的数据
	//其实就是将下标为前一个参数到下标为后面一个参数的数据都除去
	string str5("abcdef");
	str5.erase(1, 3);
	cout << str5 << endl;

	//replace,将字符串中某个位置的数据替换为我们指定的数据
	//如果那个位置的空间小于我们要输入的字符串的大小
	//它会自动扩容
	string str6("hello win !");
	str6.replace(5, 1, "%%");//将下标为5的位置,数据替换为“%%”,
	//要注意,其实这中间的1就是指只针对5这个下标的位置
	//而要是2就是指从下标5到5后面一个位置这两个位置
	cout << str6 << endl;
	str6.replace(9, 2, "%%");
	cout << str6 << endl;

}


void teststringreserve()
{
	std::string str1("hello world");

	cout << str1.size() << endl;//11个字符
	//string类中提供了capacity()函数去获取编译器为了
	//这个字符串数组开辟来了多少空间
	cout << str1.capacity() << endl;//开了15个空间
	cout << str1 << endl;

	//不过由于我们每次可能会对已经创建的字符串数组插入数据
    //那就会让编译器不断扩容
    //使得效率低下
	//上面的push_back是只能尾插进一个字符
	//下面的append是能够尾插进一个字符串
	str1.append(" hello world");
	cout << str1 << endl;
	cout << str1.size() << endl;//25
	cout << str1.capacity() << endl;//31

	//所以C++就在string类中提供了reserve函数
	//这个函数可以保留字符串数组中要有多少个空间
	str1.reserve(28);
	cout << "reserve(28):" << str1.capacity() << endl;//31
	str1.reserve(40);
	cout <<"reserve(40):" << str1.capacity() << endl;//47
	str1.reserve(20);
	cout << "reserve(20):" << str1.capacity() << endl;//47
	//但是不同编译器对reserve使用后对空间的处理不同
	//vs2026就是对于reserve的空间如果小于原本的字符串数组所占的空间的话,那么它是不会去改的
	//而要是大于,那么它会屁颠屁颠的跑去改
	//但是不会说就直接改成你所指定的空间了
	//因为存在着内存对齐,所以它会大于等于我们所指定的空间

}

void teststringoperations()
{
	string str1("hello win");
	//c_str() 是 std::string 类的成员函数,
	//主要用于将 C++ 风格的字符串(std::string)
	//转换为 C 风格的字符串(以  结尾的字符数组)
	const char* copystr1 = str1.c_str();
	printf("%s",copystr1);
	printf("
");
	printf("%s", str1.c_str());
 
	//find函数,用于查找字符串中某个指定值
	//是从前往后去寻找
	//find函数会返回那个指定值的下标
	//但是只会返回遇到的第一个指定值的下标
	string str2("hehllo whorldh");
	size_t pos1 = str2.find('h');
	cout <<"hehllo whorld的从前往后的第一个h的下标为:" << pos1 << endl;

	//ring函数,是从后往前去寻找,其他的和find函数类似
	size_t rpos = str2.rfind('h');
	cout << "hehllo whorld的从后往前的第一个h的下标为:" << rpos << endl;

	//find_first_of,一个被名字误导的函数
	//实际上它是指从某个位置开始寻找去和我们输入的字符串,注意,是字符串
	//有出现一个和我们输入的字符串中的任意一个元素相同的元素的话
	//就返回那个元素的下标
	size_t fpos = str2.find_first_of("low", 1);
	cout << fpos << endl;
	
	//那么find_last_of就是指从后往前找的,其他的和find_first_os英语
	size_t lpos = str2.find_last_of("low", 1);
	cout << lpos << endl;

	//find_first_not_of的作用就是与find_first_of相反就完了
	//find_last_not_of则是从后往前的

	//substr一个还算还行的函数
	//功能就是选取已有的字符串的某些连续数据,给一个新的string类变量
	string str3;
	str3 = str2.substr(0, 2);
	cout << str3 << endl;

	//那么我们不妨实现一下使用find函数去找空格,然后将空格替换为%
	string str4("h e l l o");
	size_t pos = str4.find(' ');
	while (pos < str4.size())
	{
		//当pos的值大于等于字符串长度的时候,也就代表字符串中找不到空格了
		//因为当find函数找不到要找的字符时,就会返回一个贼大的值
		str4[pos] = '%';
		pos = str4.find(' ', pos + 1);//从上次找到的空格的后面一个开始寻找
	}
	cout << str4 << endl;

	//那么上面的方法有点低级了,下面来个更高级的
	string str5("h e l l o w o r l d");
	string str6;//用空间换时间
	for (auto ch : str5)
	{
		if (ch == ' ')
		{
			ch = '%';
		}
		str6.push_back(ch);
	}
	cout << str6 << endl;

}

void testgetline()
{
	//getline,一个嘎嘎好使的函数
	//需要注意,它并不是string类的成员函数,是在std里面的
	//那么它的作用就是负责获取用户输入的字符串
	//在C语言中,scanf碰到“ ”就会停下
	//而在C++中,cin不会“ ”吸收进去
	//所以,就有了getline这个函数
	//这个函数一共三个参数
	//第一个参数我们直接传cin就行
	//第二个参数传被输入数据的string变量
	//第三个参数就有讲究了,它是指编译器获取的数据要到什么字符停下
	//一般默认是换行符,不过我们也可以指定
	
	string str1;
	//要先创建变量,再去用getline
	std::getline(cin, str1, ' ');//碰到空格就停下
	cout << str1 << endl;

	//string str2;
	////要先创建变量,再去用getline
	//std::getline(cin, str2);//碰到换行就停下
	//cout << str2 << endl;

}


int main()
{
	teststringconstruct();
	teststringiterator();
	teststringauto();
	teststringpush();
	teststringreserve;
	teststringoperations();
	testgetline();
	return 0;
}

希望大家能有所收获。

结语:以 string 为钥,解锁 STL 的高效世界

当你看完这篇博客,敲完最后一行 string 的示例代码,看着屏幕上正确输出的字符串时,其实你已经迈出了 STL 学习中最坚实的一步。回想一下,从 C 语言里手动管理 char 数组的小心翼翼,到 C++ 中用 string 轻松实现拼接、查找、修改,这种从 “繁琐” 到 “便捷” 的跨越,正是 STL 带给我们的核心价值 —— 把底层复杂的逻辑封装成易用的接口,让我们能更专注于业务逻辑,而非重复造轮子。

在前面的内容里,我们从 string 的基本定义出发,一点点拆解它的核心特性:自动动态内存管理让我们告别了内存泄漏和缓冲区溢出的烦恼;丰富的构造函数满足了不同场景下的初始化需求,无论是空字符串、C 风格字符串拷贝,还是重复字符填充、迭代器范围构造,都能一键实现;元素访问的多种方式([]、at ()、front ()、back ())兼顾了效率与安全性,迭代器和范围 for 循环则让遍历变得灵活又直观。而修改操作中的 push_back、append、insert、erase、replace,更是把字符串的增删改查做到了极致灵活,再加上查找、比较、子串截取这些实用功能,string 几乎能应对所有文本处理场景。

我们还特意深入了容易被忽略的内存优化点 ——reserve 预分配容量,它能帮我们避免频繁扩容带来的性能损耗;shrink_to_fit 释放多余内存,让资源利用更高效。这些细节看似微小,却能在大规模字符串操作中带来质的提升,也让我们明白,STL 的强大不仅在于 “能用”,更在于 “能用得好”。而与 C 风格字符串的交互(c_str ()、data ())、字符串与数值的转换(stoi、to_string)、STL 算法的兼容(reverse、sort),则让 string 的适配性变得极强,无论是对接 C 库函数,还是处理数据转换,都游刃有余。

我知道,大家在刚接触迭代器、移动构造、内存容量这些概念时,可能会觉得有些抽象。比如迭代器的 begin () 和 end () 边界、移动构造后原字符串的失效、reserve 预分配时的内存对齐规则,这些知识点初看容易混淆。但就像我们在示例代码中展示的那样,只要多动手实践,把每个函数都亲自测试一遍,把每个坑都踩一遍(比如迭代器失效后继续访问、getline 被 cin 残留换行符影响),就能慢慢理解其中的逻辑。编程从来不是 “看会” 的,而是 “练会” 的 —— 你在 teststringiterator 函数中手动实现正向、反向迭代器遍历,在 teststringoperations 中用 find 和 replace 替换空格,在 teststringreserve 中观察容量变化的过程,其实都是在把书本上的知识点内化成自己的能力。

string 作为 STL 容器家族的 “入门款”,不仅是一个字符串处理工具,更是我们理解 STL 设计思想的钥匙。它的封装性告诉我们,好的代码应该隐藏复杂实现,暴露简洁接口;它的兼容性体现了 STL “通用” 的设计理念,让不同组件可以无缝协作;它的性能优化则提醒我们,优秀的工具不仅要能用,还要高效。这些思想,在后续我们学习 vector、list、map 等其他容器时,都会反复出现。可以说,把 string 学透了,后续的 STL 学习就会事半功倍。

回想我们的学习路径:从 C++ 入门基础搭建语法框架,到类和对象理解面向对象思想,再到模板初阶接触泛型编程,最后落脚到 STL 的第一个容器 string。这条路径是循序渐进、层层递进的 —— 类和对象的知识帮我们理解了 string 为什么是一个 “类”,为什么能有成员函数和运算符重载;模板的知识让我们明白 string 其实是 basic_string的特化,理解了泛型编程的灵活性。现在,你已经把这些零散的知识点串联了起来,形成了完整的知识体系,这比单独学会某个函数更有价值。

接下来,STL 的学习之路还很长。我们会遇到更复杂的容器(比如 vector 的动态数组、list 的双向链表、map 的键值对存储),更强大的算法(比如排序、查找、排序、变换),更灵活的适配器(比如 stack、queue)。但请相信,有了 string 的学习基础,你已经具备了探索这些内容的能力。后续学习中,你可以带着 “对比” 的思维 —— 比如对比 vector 和 string 的内存管理方式,对比 list 和 string 的插入删除效率,对比不同容器对迭代器的支持程度,这样就能更快地找到它们的共性与差异,形成自己的知识网络。

最后,我想对大家说:编程学习是一个 “循序渐进、厚积薄发” 的过程。可能你现在觉得 string 的某些接口还记不牢,某些底层原理还理解不透,但这都没关系。重要的是保持好奇心和动手能力,遇到不懂的问题就去查文档、写测试代码,遇到实用的技巧就记下来、多复用。就像我们用 string 处理字符串一样,学习本身也是一个 “积累 - 修改 - 优化” 的过程 —— 积累知识点,修改认知误区,优化学习方法。

STL 是 C++ 的精华所在,而 string 只是这趟精彩旅程的起点。它让我们看到了 C++ 的强大与优雅,也让我们感受到了高效编程的乐趣。未来,当你用 vector 管理动态数组,用 map 实现快速查找,用 STL 算法简化复杂逻辑时,你会感谢现在认真学习 string 的自己。

请保持这份对编程的热爱与执着,继续深耕下去。相信不久的将来,你不仅能熟练运用 STL 的各种工具,还能理解其底层实现的精髓,甚至能根据需求自定义容器和算法。编程的世界没有捷径,但每一步脚踏实地的努力,都终将化为你成长路上的坚实阶梯。

愿你以 string 为钥,解锁 STL 的广阔天地,在 C++ 的学习之路上越走越远,写出更优雅、更高效、更健壮的代码!加油,每一个为梦想全力以赴的学习者!

 

本文地址:https://www.yitenyun.com/5624.html

搜索文章

Tags

#服务器 #python #pip #conda #人工智能 #微信 #ios面试 #ios弱网 #断点续传 #ios开发 #objective-c #ios #ios缓存 #远程工作 #Trae #IDE #AI 原生集成开发环境 #Trae AI 香港站群服务器 多IP服务器 香港站群 站群服务器 #kubernetes #笔记 #平面 #容器 #linux #学习方法 #运维 #log4j #ollama #飞牛nas #fnos #kylin #docker #arm #科技 #深度学习 #自然语言处理 #神经网络 #hadoop #hbase #hive #zookeeper #spark #kafka #flink #低代码 #爬虫 #音视频 #银河麒麟高级服务器操作系统安装 #银河麒麟高级服务器V11配置 #设置基础软件仓库时出错 #银河麒高级服务器系统的实操教程 #生产级部署银河麒麟服务系统教程 #Linux系统的快速上手教程 #AI编程 #学习 #飞书 #语言模型 #大模型 #ai #ai大模型 #agent #华为云 #部署上线 #动静分离 #Nginx #新人首发 #fastapi #html #css #大数据 #职场和发展 #程序员创富 #ARM服务器 # GLM-4.6V # 多模态推理 #PyTorch #模型训练 #星图GPU #分阶段策略 #模型协议 #ide #java #开发语言 #前端 #javascript #架构 #MobaXterm #ubuntu #ssh #经验分享 #安卓 #langchain #数据库 #harmonyos #鸿蒙PC #物联网 #websocket #windows #nginx #开源 #C++ #Reactor #进程控制 #驱动开发 #c++ #github #git #自动化 #ansible #云计算 #node.js #pytorch #aws #私有化部署 #tcp/ip #网络 #qt #unity #c# #游戏引擎 #区块链 #测试用例 #生活 #word #umeditor粘贴word #ueditor粘贴word #ueditor复制word #ueditor上传word图片 #gemini #gemini国内访问 #gemini api #gemini中转搭建 #Cloudflare #cpolar #fabric #postgresql #openHiTLS #TLCP #DTLCP #密码学 #商用密码算法 #android #腾讯云 #Conda # 私有索引 # 包管理 #大模型学习 #AI大模型 #大模型教程 #大模型入门 #vue上传解决方案 #vue断点续传 #vue分片上传下载 #vue分块上传下载 #jar #数信院生信服务器 #Rstudio #生信入门 #生信云服务器 #sql #AIGC #agi #内网穿透 #mysql #RTP over RTSP #RTP over TCP #RTSP服务器 #RTP #TCP发送RTP #云原生 #iventoy #VmWare #OpenEuler #风控模型 #决策盲区 #算法 #牛客周赛 #dify #ci/cd #jenkins #gitlab #pycharm #Ansible # 自动化部署 # VibeThinker #文心一言 #AI智能体 #centos #svn #后端 #机器学习 #矩阵 #线性代数 #AI运算 #向量 #flutter #Harbor #vscode #缓存 #硬件工程 #http #项目 #高并发 #mobaxterm #计算机视觉 #spring cloud #spring #vue.js #json #serverless #阿里云 #diskinfo # TensorFlow # 磁盘健康 #儿童书籍 #儿童诗歌 #童话故事 #经典好书 #儿童文学 #好书推荐 #经典文学作品 #microsoft #鸿蒙 #mcp #mcp server #AI实战 #边缘计算 #重构 #ecmascript #elementui #开源软件 #流程图 #论文阅读 #信息可视化 #c语言 #FaceFusion # Token调度 # 显存优化 #FTP服务器 #数学建模 #设备驱动 #芯片资料 #网卡 #java-ee #shell #CPU利用率 #分布式 #华为 #iBMC #UltraISO #性能优化 #2026年美赛C题代码 #2026年美赛 #spring boot #php #java大文件上传 #java大文件秒传 #java大文件上传下载 #java文件传输解决方案 #超算服务器 #算力 #高性能计算 #仿真分析工作站 #springboot #prometheus #MCP #MCP服务器 #企业开发 #ERP #项目实践 #.NET开发 #C#编程 #编程与数学 #内存治理 #django #Ubuntu服务器 #硬盘扩容 #命令行操作 #VMware #stm32 #多个客户端访问 #IO多路复用 #回显服务器 #TCP相关API #mvp #个人开发 #设计模式 #llama #opencv #CFD #mongodb #数据结构 #进程 #jmeter #功能测试 #软件测试 #自动化测试 #web安全 #安全 #蓝桥杯 #正则 #正则表达式 #mcu #信息与通信 #时序数据库 #程序人生 #科研 #博士 #游戏 #产品经理 #ui #团队开发 #墨刀 #figma #Windows 更新 #搜索引擎 #导航网 #select #PyCharm # 远程调试 # YOLOFuse #嵌入式 #大语言模型 #长文本处理 #GLM-4 #Triton推理 #Dell #PowerEdge620 #内存 #硬盘 #RAID5 #鸭科夫 #逃离鸭科夫 #鸭科夫联机 #鸭科夫异地联机 #开服 #毕业设计 #rocketmq #flask #Linux #TCP #线程 #线程池 #RAGFlow #DeepSeek-R1 #powerpoint #Com #web #webdav #chatgpt #DeepSeek #AI #DS随心转 #系统架构 #FL Studio #FLStudio #FL Studio2025 #FL Studio2026 #FL Studio25 #FL Studio26 #水果软件 #vim #gcc #yum #redis #网络协议 #lvs #负载均衡 #uni-app #小程序 #notepad++ #es安装 #scrapy #课程设计 #jvm #服务器繁忙 #SSH # ProxyJump # 跳板机 #jetty #哈希算法 #散列表 #dreamweaver #HCIA-Datacom #H12-811 #题库 #最新题库 #计算机网络 #线性回归 #transformer #AI写作 #Agent #程序员 #ffmpeg #udp #酒店客房管理系统 #毕设 #论文 #学习笔记 #jdk #https #leetcode #wsl #L2C #勒让德到切比雪夫 #ssl #深度优先 #DFS #钉钉 #机器人 #企业微信 #Android #Bluedroid #LLM #3d #arm开发 #嵌入式硬件 #堡垒机 #安恒明御堡垒机 #windterm #PowerBI #企业 #自动驾驶 #golang #vllm #Streamlit #Qwen #本地部署 #AI聊天机器人 #能源 #servlet #京东云 #语音识别 #阻塞队列 #生产者消费者模型 #服务器崩坏原因 #SSM 框架 #孕期健康 #产品服务推荐 #推荐系统 #用户交互 #数据集 #零售 #AI产品经理 #大模型开发 #mmap #nio #rabbitmq #protobuf #todesk #我的世界 #游戏私服 #云服务器 #网络安全 #全能视频处理软件 #视频裁剪工具 #视频合并工具 #视频压缩工具 #视频字幕提取 #视频处理工具 #YOLO #claude #逻辑回归 #电脑 #Canal #信号处理 #目标跟踪 #社科数据 #数据分析 #数据挖掘 #数据统计 #经管数据 #sqlserver #压枪 #DisM++ # 系统维护 #蓝耘智算 #守护进程 #复用 #screen #数据仓库 #vue3 #天地图 #403 Forbidden #天地图403错误 #服务器403问题 #天地图API #部署报错 #autosar #AI论文写作工具 #学术论文创作 #论文效率提升 #MBA论文写作 #cnn #操作系统 #智能手机 #gitee #pjsip #svm #amdgpu #kfd #ROCm #求职招聘 #面试 #everything #AB包 #Tracker 服务器 #响应最快 #torrent 下载 #2026年 #Aria2 可用 #迅雷可用 #BT工具通用 #数模美赛 #matlab #就业 #openclaw #whisper #分类 #单片机 #abtest #debian #iphone #聚类 #adb #架构师 #软考 #系统架构师 #1024程序员节 #TURN # WebRTC # HiChatBox #OCR #文字检测 #AI大模型应用开发 #HeyGem # 局域网访问 # 批量处理 #ESXi #ModelEngine #银河麒麟操作系统 #openssh #华为交换机 #信创终端 #银河麒麟 #系统升级 #信创 #国产化 #贪心算法 #pdf #gpu算力 #paddlepaddle #其他 #金融 #金融投资Agent #新浪微博 #前端框架 #支持向量机 #启发式算法 #elasticsearch #版本控制 #Git入门 #开发工具 #代码托管 #n8n #oracle #CISSP #CISSP考点 #信息安全 #CISSP哪里考 #公众号:厦门微思网络 #+微信号:xmweisi #排序算法 #插入排序 #Chat平台 #ARM架构 #考研 #软件工程 #GB/T4857 #GB/T4857.17 #GB/T4857测试 #树莓派4b安装系统 #claude code #codex #code cli #ccusage #OBC #Ascend #MindIE #twitter #openresty #lua #电气工程 #C# #PLC #ProCAST2025 #ProCast #脱模 #顶出 #应力计算 #铸造仿真 #变形计算 #ssm #laravel #里氏替换原则 #幼儿园 #园长 #幼教 #SSH Agent Forwarding # PyTorch # 容器化 #Keycloak #Quarkus #AI编程需求分析 #推荐算法 #sizeof和strlen区别 #sizeof #strlen #计算数据类型字节数 #计算字符串长度 #googlecloud #若依 #quartz #框架 #需求分析 #scala #测试工具 #压力测试 #七年级上册数学 #有理数 #有理数的加法法则 #绝对值 #流量运营 #用户运营 # 服务器IP访问 # 端口映射 #react native #react.js #epoll #高级IO #文生视频 #CogVideoX #AI部署 #改行学it #创业创新 #无人机 #Deepoc #具身模型 #开发板 #未来 #pandas #matplotlib #智能路由器 #环境搭建 #tomcat #firefox #tdengine #制造 #涛思数据 #rust #双指针 #机器视觉 #6D位姿 #asp.net #Proxmox VE #虚拟化 #硬件 #LoRA # RTX 3090 # lora-scripts #流量监控 #GPU服务器 #8U #硬件架构 #fiddler #rtmp #银河麒麟部署 #银河麒麟部署文档 #银河麒麟linux #银河麒麟linux部署教程 #ddos #windbg分析蓝屏教程 #串口服务器 #Modbus #IFix #MC #数组 #fastmcp #ROS #H5 #跨域 #发布上线后跨域报错 #请求接口跨域问题解决 #跨域请求代理配置 #request浏览器跨域 #长文本理解 #glm-4 #推理部署 #macos #几何学 #拓扑学 #链表 #链表的销毁 #链表的排序 #链表倒置 #判断链表是否有环 #JumpServer #UDP的API使用 #电商 #anaconda #虚拟环境 #fpga开发 #LVDS #高速ADC #DDR #游戏机 #振镜 #振镜焊接 #数据结构与算法 #人脸识别 #人脸核身 #活体检测 #身份认证与人脸对比 #微信公众号 #Modbus-TCP #python学习路线 #python基础 #python进阶 #python标准库 #web3 #ai编程 #ICPC #azure #测试流程 #金融项目实战 #P2P #编辑器 #ISP Pipeline #行缓冲 #智慧校园解决方案 #智慧校园一体化平台 #智慧校园选型 #智慧校园采购 #智慧校园软件 #智慧校园专项资金 #智慧校园定制开发 #LangGraph #模型上下文协议 #MultiServerMCPC #load_mcp_tools #load_mcp_prompt #dubbo #SRS #流媒体 #直播 #微信小程序 #ida #webrtc #glibc #中间件 #研发管理 #禅道 #禅道云端部署 #ONLYOFFICE #MCP 服务器 #论文笔记 #游戏美术 #技术美术 #游戏策划 #游戏程序 #用户体验 #zabbix #STUN # TURN # NAT穿透 #蓝牙 #LE Audio #BAP #RAID #RAID技术 #磁盘 #存储 #Coze工作流 #AI Agent指挥官 #多智能体系统 #Nacos #微服务 #HBA卡 #RAID卡 #VS Code调试配置 #xlwings #Excel #测试覆盖率 #单元测试 #可用性测试 #unity3d #服务器框架 #Fantasy #lstm #llm #智慧城市 #海外短剧 #海外短剧app开发 #海外短剧系统开发 #短剧APP #短剧APP开发 #短剧系统开发 #海外短剧项目 #pytest #visual studio code #prompt #Cpolar #国庆假期 #服务器告警 #工业级串口服务器 #串口转以太网 #串口设备联网通讯模块 #串口服务器选型 #mamba #Node.js #漏洞检测 #CVE-2025-27210 #凤希AI伴侣 #我的世界服务器搭建 #minecraft #生信 #FRP #journalctl #远程连接 #wordpress #雨云 #LobeChat #vLLM #GPU加速 #selenium #RAG #全链路优化 #实战教程 #xeon #UDP套接字编程 #UDP协议 #网络测试 #SSE #eBPF #SSH反向隧道 # Miniconda # Jupyter远程访问 #grafana #mapreduce #maven #.net #homelab #Lattepanda #Jellyfin #Plex #Emby #Kodi #TensorRT # Triton # 推理优化 #asp.net大文件上传 #asp.net大文件上传下载 #asp.net大文件上传源码 #ASP.NET断点续传 #asp.net上传文件夹 #SSH别名 # CUDA #三种参数 #参数的校验 #fastAPI #gpu #nvcc #cuda #nvidia #目标检测 #YOLO26 #YOLO11 #计算机 #连锁药店 #连锁店 #建筑缺陷 #红外 #结构体 #ping通服务器 #读不了内网数据库 #bug菌问答团队 #漏洞 #数码相机 # 公钥认证 #命令模式 # AI翻译机 # 实时翻译 #Ubuntu #Steam #饥荒联机版 #clickhouse #零代码平台 #AI开发 #代理 #5G #平板 #交通物流 #智能硬件 #CNAS #CMA #程序文件 #图像处理 #yolo #CPU #监测 #监控 #自动化运维 #IO #插件 #敏捷流程 #esp32教程 #行为模式分析 #数据 #应用层 #跨领域 #敏感信息 #apache #r-tree #模版 #函数 #类 #笔试 #心理健康服务平台 #心理健康系统 #心理服务平台 #心理健康小程序 #visual studio #北京百思可瑞教育 #百思可瑞教育 #北京百思教育 #risc-v #WEB #ms-swift # 一锤定音 # 大模型微调 #deepseek #高品质会员管理系统 #收银系统 #同城配送 #最好用的电商系统 #最好用的系统 #推荐的前十系统 #JAVA PHP 小程序 #VibeVoice # 语音合成 #LabVIEW知识 #LabVIEW程序 #labview #LabVIEW功能 #ipv6 #SSH公钥认证 # 安全加固 #dynadot #域名 #Fun-ASR # 语音识别 # WebUI #密码 #cpp #交互 #CUDA #Docker #dba #echarts #Rust #NPU #CANN ##程序员和算法的浪漫 #SMP(软件制作平台) #EOM(企业经营模型) #应用系统 #AI助手 #企业微信集成 #轻量大模型 #list #NAS #飞牛NAS #NVR #EasyNVR #Qwen3-14B # 大模型部署 # 私有化AI #项目申报系统 #项目申报管理 #项目申报 #企业项目申报 #wpf #JAVA #Java #ue4 #ue5 #DedicatedServer #独立服务器 #专用服务器 #vp9 #AutoDL #安全架构 #vue #screen 命令 #运维开发 #opc ua #opc #语义搜索 #嵌入模型 #Qwen3 #AI推理 #大剑师 #nodejs面试题 # GLM-TTS # 数据安全 #Shiro #反序列化漏洞 #CVE-2016-4437 #chrome #支付 #指针 #远程桌面 #远程控制 #Gunicorn #WSGI #Flask #并发模型 #容器化 #Python #性能调优 #职场发展 #embedding #bash #运营 #React安全 #漏洞分析 #Next.js #源代码管理 # 目标检测 #chat #ip #高仿永硕E盘的个人网盘系统源码 #ceph #阳台种菜 #园艺手扎 #Gemini #Nano Banana Pro #汽车 #typescript #npm #VPS #搭建 #土地承包延包 #领码SPARK #aPaaS+iPaaS #数字化转型 #智能审核 #档案数字化 #SAP #ebs #metaerp #oracle ebs #SSH跳转 #RustDesk # IndexTTS # GPU集群 #状态模式 #框架搭建 #个人博客 #媒体 #Moltbot #2026AI元年 #年度趋势 #国产PLM #瑞华丽PLM #瑞华丽 #PLM #Anaconda配置云虚拟环境 #C语言 #vivado license # 远程访问 # 服务器IP配置 #捷配 #pcb工艺 #jupyter #WinSCP 下载安装教程 #SFTP #FTP工具 #服务器文件传输 #MS #Materials #可信计算技术 #区间dp #二进制枚举 #图论 #winscp #智能体 #多线程 #性能调优策略 #双锁实现细节 #动态分配节点内存 #markdown #建站 #跳槽 #业界资讯 #google #search # 双因素认证 #DDD #tdd #powerbi #go #嵌入式编译 #ccache #distcc #策略模式 #K8s #镜像 #集群自动化 # IndexTTS 2.0 # 远程运维 #Miniconda #cursor #puppeteer #进程创建与终止 #bytebase #TFTP #客户端 #spine #GLM-4.6V-Flash-WEB # AI视觉 # 本地部署 #性能测试 #LoadRunner #bootstrap #tensorflow #wps #工厂模式 #Karalon #AI Test #Moltbook #Clawdbot #IndexTTS 2.0 #本地化部署 #YOLOv8 # Docker镜像 #文件IO #输入输出流 #log #tcpdump #IndexTTS2 # 阿里云安骑士 # 木马查杀 #cascadeur #设计师 #SEO优化 #车辆排放 #浏览器自动化 #python #SA-PEKS # 关键词猜测攻击 # 盲签名 # 限速机制 #PyTorch 特性 #动态计算图 #张量(Tensor) #自动求导Autograd #GPU 加速 #生态系统与社区支持 #与其他框架的对比 #Spring AI #STDIO协议 #Streamable-HTTP #McpTool注解 #服务器能力 #CMake #Make #C/C++ #paddleocr #SSH免密登录 #集成测试 #静脉曲张 #腿部健康 #spring native #智能一卡通 #门禁一卡通 #梯控一卡通 #电梯一卡通 #消费一卡通 #一卡通 #考勤一卡通 #排序 #远程访问 #远程办公 #飞网 #安全高效 #配置简单 # 高并发部署 #pencil #pencil.dev #设计 #vps #Anything-LLM #IDC服务器 #工具集 #simulink #aiohttp #asyncio #异步 #逆向工程 #软件 #本地生活 #电商系统 #商城 #ngrok #sqlite #Playbook #AI服务器 #RK3576 #瑞芯微 #硬件设计 #css3 #社交智慧 #职场生存 #系统思维 #身体管理 #商务宴请 #拒绝油腻 #清醒日常 #学术写作辅助 #论文创作效率提升 #AI写论文实测 #Triton #iot #智能家居 #p2p #Spring #Spring Boot #RPA #影刀RPA #AI办公 #intellij-idea #database #idea #galeweather.cn #高精度天气预报数据 #光伏功率预测 #风电功率预测 #高精度气象 #rdp #健康医疗 #教育电商 #海外服务器安装宝塔面板 #翻译 #开源工具 #910B #SSH保活 #远程开发 #openlayers #bmap #tile #server #贴图 #材质 #爱心代码 #表白代码 #爱心 #tkinter #情人节表白代码 #mybatis #测评 # GLM-4.6V-Flash-WEB # 显卡驱动备份 #联机教程 #局域网联机 #局域网联机教程 #局域网游戏 #虚拟机 #EMC存储 #存储维护 #NetApp存储 #简单数论 #埃氏筛法 #openEuler #Hadoop #DIY机器人工房 #JT/T808 #车联网 #车载终端 #模拟器 #仿真器 #开发测试 #vuejs #nacos #银河麒麟aarch64 #uvicorn #uvloop #asgi #event #yolov12 #研究生life #nas #音乐分类 #音频分析 #ViT模型 #Gradio应用 #鼠大侠网络验证系统源码 #AI赋能盾构隧道巡检 #开启基建安全新篇章 #以注意力为核心 #YOLOv12 #AI隧道盾构场景 #盾构管壁缺陷病害异常检测预警 #隧道病害缺陷检测 #信令服务器 #Janus #MediaSoup #Deepseek #gpt-3 #ARM64 # DDColor # ComfyUI #Jetty # CosyVoice3 # 嵌入式服务器 #鸿蒙系统 #系统安全 #车载系统 #群晖 #音乐 #企业架构治理 #电力企业IT架构 #IT架构设计 #excel #Fluentd #Sonic #日志采集 #restful #ajax #转行 #Claude #SMTP # 内容安全 # Qwen3Guard #视频去字幕 #flume #X11转发 #外卖配送 #处理器模块 #现货库存 #价格优惠 #PM864AK01 #3BSE018161R1 #控制器模块 #可撤销IBE #服务器辅助 #私钥更新 #安全性证明 #双线性Diffie-Hellman #空间计算 #原型模式 #迁移重构 #数据安全 #代码迁移 #榛樿鍒嗙被 #CTF #mariadb #gateway #Comate #遛狗 #bug #网络编程 #I/O模型 #并发 #水平触发、边缘触发 #多路复用 #实在Agent #UDP #SSH复用 # 远程开发 #C++ UA Server #SDK #Windows #跨平台开发 #聊天小程序 #eclipse #arm64 #OPCUA #OSS #MOXA #GATT服务器 #蓝牙低功耗 #分库分表 #垂直分库 #水平分表 #雪花算法 #分布式ID #跨库查询 #渗透测试 #服务器解析漏洞 #nodejs #云服务器选购 #Saas #UOS #海光K100 #统信 #NFC #智能公交 #服务器计费 #FP-增长 #outlook #错误代码2603 #无网络连接 #2603 #mssql #注入漏洞 #练习 #基础练习 #循环 #九九乘法表 #计算机实现 #青少年编程 #esb接口 #走处理类报异常 #考试系统 #在线考试 #培训考试 #考试练习 #safari #具身智能 # 硬件配置 #思维模型 #认知框架 #认知 #算力一体机 #ai算力服务器 #昇腾300I DUO #docker-compose #smtp #smtp服务器 #PHP #vrrp #脑裂 #keepalived主备 #高可用主备都持有VIP #intellij idea #coffeescript #软件需求 #寄存器 #le audio #低功耗音频 #通信 #连接 #部署 #cosmic #知识库 #vnstat #c++20 # 远程连接 #tornado #fs7TF #H3C #攻防演练 #Java web #红队 #reactjs #Aluminium #Google #学工管理系统 #学工一体化平台 #学工软件二次开发 #学工平台定制开发 #学工系统服务商 #学工系统源头厂家 #智慧校园学工系统 #鲲鹏 #昇腾 #npu #vmware #API限流 # 频率限制 # 令牌桶算法 #TTS私有化 # 音色克隆 #处理器 #因果学习 #ansys #ansys问题解决办法 #网络攻击模型 #黑群晖 #无U盘 #纯小白 #cocoa #tcp/ip #网络 #GB28181 #SIP信令 #SpringBoot #视频监控 #远程软件 #SSH跳板机 # Python3.11 #WT-2026-0001 #QVD-2026-4572 #smartermail #东方仙盟 #teamviewer #蓝湖 #Axure原型发布 #gitea #视频 #Tetrazine-Acid #1380500-92-4 #分布式数据库 #集中式数据库 #业务需求 #选型误 #1panel # Connection refused #elk #Socket网络编程 #工作 #视觉检测 #turn #黑客技术 #网安应急响应 #微PE # GLM # 服务连通性 #Apple AI #Apple 人工智能 #FoundationModel #Summarize #SwiftUI #ambari #汇编 #门禁 #梯控 #智能梯控 #uv #uvx #uv pip #npx #Ruff # 服务器配置 # GPU # 高并发 #数据恢复 #视频恢复 #视频修复 #RAID5恢复 #流媒体服务器恢复 #claude-code #软件开发 #农产品物流管理 #物流管理系统 #农产品物流系统 #农产品物流 #xss #muduo库 #LangFlow # 轻量化镜像 # 边缘计算 #Tokio #milvus #web server #请求处理流程 #未加引号服务路径 #postman #服务器开启 TLS v1.2 #IISCrypto 使用教程 #TLS 协议配置 #IIS 安全设置 #服务器运维工具 #VSCode # SSH #RSO #机器人操作系统 # TTS服务器 # 键鼠锁定 #mtgsig #美团医药 #美团医药mtgsig #美团医药mtgsig1.2 #opc模拟服务器 #MQTT协议 #卷积神经网络 #dash #CVE-2025-68143 #CVE-2025-68144 #CVE-2025-68145 #Socket #套接字 #I/O多路复用 #字节序 #html5 #weston #x11 #x11显示服务器 # 批量部署 #创业管理 #财务管理 #团队协作 #创始人必修课 #数字化决策 #经营管理 #copilot #证书 # 大模型 # ms-swift #结构与算法 #服务器线程 # SSL通信 # 动态结构体 #政务 #语音生成 #TTS #集成学习 #TLS协议 #HTTPS #漏洞修复 #运维安全 #easyui #大学生 #大作业 #个人助理 #数字员工 #JNI #扩展屏应用开发 #android runtime #域名注册 #新媒体运营 #网站建设 #国外域名 # 数字人系统 # 远程部署 #sentinel #KMS #slmgr #宝塔面板部署RustDesk #RustDesk远程控制手机 #手机远程控制 #rustdesk #可再生能源 #绿色算力 #风电 #esp32 #mosquito #连接数据库报错 #麦克风权限 #访问麦克风并录制音频 #麦克风录制音频后在线播放 #用户拒绝访问麦克风权限怎么办 #uniapp 安卓 苹果ios #将音频保存本地或上传服务器 # GPU服务器 # tmux #漏洞挖掘 #Exchange #动态规划 #DNS #Discord机器人 #云部署 #程序那些事 #dlms #dlms协议 #逻辑设备 #逻辑设置间权限 #智能体从0到1 #新手入门 #安全威胁分析 #源码 #闲置物品交易系统 #TRO #TRO侵权 #TRO和解 #效率神器 #办公技巧 #自动化工具 #Windows技巧 #打工人必备 #仙盟创梦IDE #运维工具 #YOLOFuse # Base64编码 # 多模态检测 #IPv6 # 黑屏模式 #前端开发 #EN4FE #C #领域驱动 #树莓派 #N8N #自由表达演说平台 #演说 #移动端h5网页 #调用浏览器摄像头并拍照 #开启摄像头权限 #拍照后查看与上传服务器端 #摄像头黑屏打不开问题 #nfs #iscsi #AI Agent #开发者工具 #SPA #单页应用 #web3.py #kmeans #数字孪生 #三维可视化 # Qwen3Guard-Gen-8B #SQL调优 #EXPLAIN #慢查询日志 #分布式架构 #后端开发 #Minecraft #Minecraft服务器 #PaperMC #我的世界服务器 #ipmitool #BMC #范式 #入侵 #日志排查 #晶振 #WinDbg #Windows调试 #内存转储分析 #随机森林 #麒麟OS #文件管理 #文件服务器 #国产开源制品管理工具 #Hadess #一文上手 #swagger #kong #Kong Audio #Kong Audio3 #KongAudio3 #空音3 #空音 #中国民乐 #AI视频创作系统 #AI视频创作 #AI创作系统 #AI视频生成 #AI工具 #AI创作工具 #夏天云 #夏天云数据 #hdfs #华为od #华为od机试 #华为od机考 #华为od最新上机考试题库 #华为OD题库 #华为OD机试双机位C卷 #od机考题库 #ET模式 #非阻塞 #高并发服务器 #AI+ #coze #AI入门 #AI赋能 #计组 #数电 # 模型训练 #运维 #工程实践 #pve #Python3.11 #CLI #JavaScript #langgraph.json #图像识别 #知识图谱 #React #Next #CVE-2025-55182 #RSC #raid #raid阵列 #KMS激活 #clawdbot #上下文工程 #langgraph #意图识别 #gpt #API #taro #单例模式 #快递盒检测检测系统 #bigtop #hdp #hue #kerberos #QQbot #QQ #智能电视 #数据采集 #浏览器指纹 #vertx #vert.x #vertx4 #runOnContext #ESP32 #传感器 #MicroPython #WRF #WRFDA #百度 #欧拉 #CSDN #HarmonyOS #AutoDL使用教程 #AI大模型训练 #linux常用命令 #PaddleOCR训练 #edge #迭代器模式 #观察者模式 #机器人学习 #CosyVoice3 # IP配置 # 0.0.0.0 #Syslog #系统日志 #日志分析 #日志监控 #网络配置实战 #Web/FTP 服务访问 #计算机网络实验 #外网访问内网服务器 #Cisco 路由器配置 #静态端口映射 #网络运维 #生产服务器问题查询 #日志过滤 #防火墙 # 水冷服务器 # 风冷服务器 #VoxCPM-1.5-TTS # 云端GPU # PyCharm宕机 #webpack #儿童AI #图像生成 #gRPC #注册中心 #异步编程 #系统编程 #Pin #http服务器 #服务器架构 #AI推理芯片 #材料工程 #AI生成 # outputs目录 # 自动化 #挖漏洞 #攻击溯源 #编程 #stl #IIS Crypto #blender #warp #libosinfo #Go并发 #高并发架构 #Goroutine #系统设计 #Dify #net core #kestrel #web-server #asp.net-core #esp32 arduino #HistoryServer #Spark #YARN #jobhistory #勒索病毒 #勒索软件 #加密算法 #.bixi勒索病毒 #数据加密 #FASTMCP #CA证书 #sglang #ZooKeeper #ZooKeeper面试题 #面试宝典 #深入解析 #大模型部署 #mindie #大模型推理 #ComfyUI # 推理服务器 #UEFI #BIOS #Legacy BIOS #产品运营 #内存接口 # 澜起科技 # 服务器主板 #Puppet # IndexTTS2 # TTS #模拟退火算法 #Host #SSRF #知识 #科普 #星际航行 #三维重建 #高斯溅射 #agentic bi #论文复现 #sql注入 #x86_64 #数字人系统 #MC群组服务器 # 服务器迁移 # 回滚方案 #osg #windows11 #系统修复 #娱乐 #计算机毕业设计 #程序定制 #毕设代做 #课设 #文件传输 #电脑文件传输 #电脑传输文件 #电脑怎么传输文件到另一台电脑 #电脑传输文件到另一台电脑 #说话人验证 #声纹识别 #CAM++ #云开发 #性能 #优化 #RAM #KMS 激活 #AI智能棋盘 #Rock Pi S #wireshark #华为od机考真题 #华为od机试真题 #华为OD上机考试真题 #华为OD上机考试双机位C卷 #华为ODFLASH坏块监测系统 #rtsp #转发 #unix #CS2 #debian13 #BoringSSL #cocos2d #图形渲染 #AI技术 #PTP_1588 #gPTP #学术生涯规划 #CCF目录 #基金申请 #职称评定 #论文发表 #科研评价 #顶会顶刊 #IT #技术 # ARM服务器 # 鲲鹏 #IntelliJ IDEA #neo4j #NoSQL #SQL #http头信息 #Llama-Factory # 大模型推理 #Coturn #k8s #节日 #ESP32编译服务器 #Ping #DNS域名解析 #Kuikly #openharmony #moltbot #ICE #信创国产化 #达梦数据库 #RXT4090显卡 #RTX4090 #深度学习服务器 #硬件选型 #万悟 #联通元景 # REST API #TCP服务器 #开发实战 #SMARC #ARM # keep-alive # 代理转发 #idm #网站 #截图工具 #批量处理图片 #图片格式转换 #图片裁剪 #地理 #遥感 #reactor反应堆 #面向对象 #进程等待 #wait #waitpid #温湿度监控 #WhatsApp通知 #IoT #MySQL # 服务器IP # 端口7860 # 离线AI #clamav #健身房预约系统 #健身房管理系统 #健身管理系统 #web服务器 #文件上传漏洞 #ThingsBoard MCP #Kylin-Server #国产操作系统 #服务器安装 #Android16 #音频性能实战 #音频进阶 #短剧 #短剧小程序 #短剧系统 #微剧 # 智能运维 # 性能瓶颈分析 # GPU租赁 # 自建服务器 #hibernate #nosql # 云服务器 #H5网页 #网页白屏 #H5页面空白 #资源加载问题 #打包部署后网页打不开 #HBuilderX #A2A #GenAI #智能体来了 #传统行业 #VMWare Tool #MinIO服务器启动与配置详解 #语义检索 #向量嵌入 #数据访问 #.netcore #人脸活体检测 #live-pusher #动作引导 #张嘴眨眼摇头 #苹果ios安卓完美兼容 #磁盘配额 #存储管理 #形考作业 #国家开放大学 #系统运维 #gnu #DHCP #网络安全大赛 #glances #duckdb #强化学习 #策略梯度 #REINFORCE #蒙特卡洛 #ueditor导入word #STL #string #实时检测 #DAG # ControlMaster #阿里云RDS #HarmonyOS APP #cesium #可视化 #b树 #SSH密钥 #LED #设备树 #GPIO #memory mcp #Cursor #数据可视化 #网路编程 #百万并发 #声源定位 #MUSIC #AI电商客服 #C₃₂H₄₅N₇O₁₁S₂ #Buck #NVIDIA #交错并联 #DGX #ServBay #C2000 #TI #实时控制MCU #AI服务器电源 # 树莓派 # ARM架构 #gerrit #AI 推理 #NV #memcache # OTA升级 # 黄山派 #全栈 #内网 # 网络延迟 #ranger #MySQL8.0 #Qwen3-VL # 服务状态监控 # 视觉语言模型 #智能体对传统行业冲击 #行业转型 #系统管理 #服务 #传媒 #隐函数 #常微分方程 #偏微分方程 #线性微分方程 #线性方程组 #非线性方程组 #复变函数 #代理服务器 #screen命令 #UDP服务器 #recvfrom函数 #超时设置 #客户端/服务器 #挖矿 #Linux病毒 #管道Pipe #system V #odoo #计算机现代史 #雨云服务器 #教程 #MCSM面板 #claudeCode #content7 #Ward #IPMI #appche #高精度农业气象 #递归 #线性dp #muduo #TcpServer #accept #webgl #AI-native #VMware Workstation16 #服务器操作系统 #音诺ai翻译机 #AI翻译机 # Ampere Altra Max #国产化OS #华为机试 #OpenHarmony #sklearn #文本生成 #CPU推理 #4U8卡 AI 服务器 ##AI 服务器选型指南 #GPU 互联 #GPU算力 #ShaderGraph #图形 #ftp #sftp #uniapp #合法域名校验出错 #服务器域名配置不生效 #request域名配置 #已经配置好了但还是报错 #uniapp微信小程序 #日志模块 #ASR #SenseVoice #硬盘克隆 #DiskGenius #ueditor导入pdf #工程设计 #预混 #扩散 #燃烧知识 #层流 #湍流 #量子计算 #计算几何 #斜率 #方向归一化 #叉积 #samba # 批量管理 #xml #PN 结 #ArkUI #ArkTS #鸿蒙开发 #node #超算中心 #PBS #lsf #反向代理 #报表制作 #职场 #用数据讲故事 #手机h5网页浏览器 #安卓app #苹果ios APP #手机电脑开启摄像头并排查 #MCP服务器注解 #异步支持 #方法筛选 #声明式编程 #自动筛选机制 #pxe #CCE #Dify-LLM #Flexus #参数估计 #矩估计 #概率论 #投标 #标书制作 #mvc #idc #系统安装 #铁路桥梁 #DIC技术 #箱梁试验 #裂纹监测 #四点弯曲 #题解 #图 #dijkstra #迪杰斯特拉 #MinIO #gmssh #宝塔 #程序开发 #程序设计 #智能制造 #供应链管理 #工业工程 #库存管理 #POC #问答 #交付 #pyqt #AI应用编程 # 自动化运维 #r语言 #NSP #下一状态预测 #aigc #运动 #旅游 #STDIO传输 #SSE传输 #WebMVC #WebFlux #RK3588 #RK3588J #评估板 #核心板 #嵌入式开发 #服务器IO模型 #非阻塞轮询模型 #多任务并发模型 #异步信号模型 #多路复用模型 #边缘AI # Kontron # SMARC-sAMX8 #提词器 #西门子 #汇川 #Blazor #经济学 #zygote #应用进程 #SSH代理转发 #OpenManage #scanf #printf #getchar #putchar #cin #cout #remote-ssh #小艺 #搜索 #resnet50 #分类识别训练 #代理模式 #Spring AOP #GPU #租显卡 #训练推理 #企业微信机器人 #本地大模型 #AI应用 #Xshell #Finalshell #生物信息学 #组学 #Spire.Office #多进程 #python技巧 #隐私合规 #网络安全保险 #法律风险 #风险管理 #高考 #企业级存储 #网络设备 #多模态 #微调 #超参 #LLamafactory #Smokeping #大模型应用 #API调用 #PyInstaller打包运行 #服务端部署 #Linux多线程 #统信UOS #win10 #qemu #Java程序员 #Java面试 #Spring源码 #zotero #WebDAV #同步失败 #轻量化 #低配服务器 #麒麟 #V11 #kylinos #信息收集 #Langchain-Chatchat # 国产化服务器 # 信创 #公共MQTT服务器 #win11 # 模型微调 # DIY主机 # 交叉编译 #Autodl私有云 #深度服务器配置 #0day漏洞 #DDoS攻击 #漏洞排查 #懒汉式 #恶汉式 #实体经济 #商业模式 #数智红包 #商业变革 #创业干货 #视觉理解 #Moondream2 #多模态AI #语音合成 #c #VMware创建虚拟机 #路由器 #Redis #分布式锁 #CS336 #Assignment #Experiments #TinyStories #Ablation #实时音视频 #m3u8 #HLS #移动端H5网页 #APP安卓苹果ios #监控画面 直播视频流 #Zabbix #n8n解惑 #余行补位 #意义对谈 #余行论 #领导者定义计划 #ARMv8 #内存模型 #内存屏障 #AE #身体实验室 #健康认知重构 #微行动 #NEAT效应 #亚健康自救 #ICT人 #eureka #广播 #组播 #并发服务器 #c++高并发 #AITechLab #cpp-python #CUDA版本 #Termux #Samba #企业存储 #RustFS #对象存储 #高可用 #三维 #3D #云计算运维 #asp.net上传大文件 #uip #设计规范 #放大电路 #模块 #CVE-2025-61686 #路径遍历高危漏洞 #全文检索 #银河麒麟服务器系统 #游戏服务器断线 #期刊 #SCI #基础语法 #标识符 #常量与变量 #数据类型 #运算符与表达式 ##租显卡 #Linly-Talker # 数字人 # 服务器稳定性 #百度文库 #爱企查 #旋转验证码 #验证码识别 #主板 #总体设计 #电源树 #框图 #devops #Archcraft #vncdotool #链接VNC服务器 #如何隐藏光标 #starrocks #Taiji #FHSS #电子电气架构 #系统工程与系统架构的内涵 #Routine #格式工厂 #L6 #L10 #L9 #lucene #算力建设 #ETL管道 #向量存储 #数据预处理 #DocumentReader #composer #symfony #java-zookeeper #nmodbus4类库使用教程 #spring ai #oauth2 # 高温监控 #个性化推荐 #BERT模型 #proc # 环境迁移 #AI运维 #DevOps自动化 #pipeline #Transformers #NLP #编程助手 #思爱普 #SAP S/4HANA #ABAP #NetWeaver # 串口服务器 # NPort5630 #一人公司 #独立开发者 #WAN2.2 #Gateway #认证服务器集成详解 #cpu #EventLoop #统信操作系统 #后端框架 #RWK35xx #语音流 #实时传输 #人形机器人 #人机交互 #数据迁移 #电梯 #电梯运力 #电梯门禁 #字符串 #时间复杂度 #空间复杂度 #adobe #free #vmstat #sar #bond #服务器链路聚合 #网卡绑定 #数据报系统 #express #cherry studio # child_process #scikit-learn #编程语言 #okhttp #图像分类 #图像分割 #yolo26算法 #人大金仓 #Kingbase #江协 #瑞萨 #OLED屏幕移植 #OpenAI #故障 #AI工具集成 #容器化部署 #2025年 #Beidou #北斗 #SSR #docker安装seata #Matrox MIL #二次开发 #CMC #poll #numpy #AI教程 #一周会议与活动 #ICLR #CCF #自动化巡检 # AI部署 #人脸识别sdk #视频编解码 #远程更新 #缓存更新 #多指令适配 #物料关联计划 #istio #服务发现 #SEW #赛威 #SEW变频器 #Prometheus #决策树 #二值化 #Canny边缘检测 #轮廓检测 #透视变换 #DooTask #防毒面罩 #防尘面罩 #交换机 #三层交换机 #ossinsight #开关电源 #热敏电阻 #PTC热敏电阻 #个人电脑 #rag #canvas层级太高 #canvas遮挡问题 #盖住其他元素 #苹果ios手机 #安卓手机 #调整画布层级 #测速 #iperf #iperf3 #SQL注入主机 #分子动力学 #化工仿真 # 权限修复 #小智 #junit #api #key #AI作画 #戴尔服务器 #戴尔730 #装系统 #boltbot #xshell #host key #tekton #rsync # 数据同步 #DuckDB #协议 #YOLO识别 #YOLO环境搭建Windows #YOLO环境搭建Ubuntu #Python办公自动化 #Python办公 #Arduino BLDC #核辐射区域探测机器人 #计算机外设 #基金 #股票 #jquery #fork函数 #进程创建 #进程终止 #session #JADX-AI 插件