【C++】认识使用string类

【C++】STL中的string类

  • C语言中的字符串
  • 标准库中的string类
  • string类
  • 成员变量
  • string类的常用接口说明
    • 成员函数
      • string(constructor构造函数)
      • ~string(destructor析构函数)
      • 默认赋值运算符重载函数
    • 遍历string
      • 下标+[ ]
      • 迭代器
      • 范围for
      • 反向迭代器
    • capacity
      • size
      • length
      • max_size
      • resize
      • capacity
      • reserve
      • clear
      • empty
    • Element access(元素访问)
      • operator[ ]
      • at
    • Modifiers(字符串进行修改)
      • operator+=
      • append
      • push_back
      • assign
      • insert
      • erase
      • replace
      • swap
    • String operations(字符串进行操作)
      • c_str
      • copy
      • find
      • rfind
      • find_first_of
      • find_last_of
      • find_first_not_of
      • find_last_not_of
      • substr
      • compare
    • Member constants(成员常量)
      • npos
    • Non-member function overloads(非成员函数重载)
      • operator+ (string)
      • relational operators (string)
      • swap (string)
      • operator>> (string)
      • operator<< (string)
      • getline (string)

链接: string

C语言中的字符串

C语言中,字符串是以’\0’结尾的一些字符的集合,为了方便操作,C标准库里面提供了一些str系列的库函数,但是这些库函数与字符串是分离开的,不太复合OOP(OOP即面向对象程序设计,全称为Object Oriented Programming)的思想,而且底层空间需要用户自己管理,可能还会又越界访问。

标准库中的string类

1.字符串是表示字符序列的类
2.标准的字符串类提供了对此类对象的支持,其接口类似于标准字符容器的接口,但添加了专门用于操作单字节字符字符串的设计特性
3.string类是使用char(即作为它的字符类型,使用它的char_traits和分配器类型)
4.string类是basic_string模板类的一个实例,它使用char来实例化basic_string模板类,并用char_traits和allocator作为basic_string的默认参数
5.注意这个类独立于所使用的编码来处理字节:如果用来处理多字节或变长字符的序列,这个类的所有成员(如长度或者大小)已经它的迭代器,将仍然按照字节(而不是实际编码的字符)来操作

总结
1.string是表示字符串的字符串类
2.该类的接口与常规容器的接口基本相同,再添加一些专门用来操作string的常规操作
3.shring再底层实际是:basic_string模板类的别名,typedef basic_string<char,char_traits,allocator>string;
4.不能操作多字节或者变长字符的序列

【注意】在使用string类时,必须包含#include头文件以及using namespace std;

string类

在这里插入图片描述

  • string 类

1.strings是代表一系列字符的对象。
2.这个标准字符串类提供支持这样的对象有类似于标准字节容器的接口,但是增加了尤其是专门设计去处理单字节字符的字符串的功能
3.这个字符串类是一个标准字符串类的模板的实例,使用类似的字符类型char
4.注意此类是独立于之前的编码去处理字节:如果去处理多字节或者可变长度字符,则此类的所有成员及其迭代器仍然以字节为单位进行操作。

成员变量

在这里插入图片描述

string类的常用接口说明

成员函数

string(constructor构造函数)

在这里插入图片描述

  • string构造函数
  • 初始化字符串对象,初始化的值取决于使用的构造函数的版本。

(1)无参构造函数(默认构造函数)

default (1)
string();

构造一个空的字符串,长度为0的字符

	string s1;

(2)拷贝构造函数

copy (2)
string (const string& str);

构造一个字符串的拷贝

	string s2("hello world!");
	string s3(s2);

(3)substring构造函数

substring (3)
string (const string& str, size_t pos, size_t len = npos);

拷贝部分字符串,在pos位置的字符开始,len字符数的间隔

	string s4("Hello world!", 6, 5);//wor
	string s5(s3, 0, 1);//w

(4)拷贝字符串的构造函数

from c-string (4)
string (const char* s);

拷贝指向c-字符串,以null为终止的字符串。

	string s6("Hello!");

(5)拷贝部分字符串的构造函数

from sequence (5)
string (const char* s, size_t n);

在指向c-字符串的字符串数组中拷贝前n个字符。

	string s7("Hello!", 2);//He

(6)填充字符的构造函数

fill (6)
string (size_t n, char c);

用字符c的n个连续的字符填充字符串。

	string s8("x", 8);//xxxxxxxx

~string(destructor析构函数)

在这里插入图片描述

  • 字符串析构函数
  • 销毁字符串对象

字符串析构函数解除分配字符串分配的所有存储空间。

int main()
{
	string s1("hello world!");
	s1.~string();
	return 0;
}

存在默认析构函数,所有可以不写。

默认赋值运算符重载函数

在这里插入图片描述

  • string::operator=
  • 字符串的分配
  • 给字符串分配一个新的值,取代当前的内容。

(1)string

string& operator= (const string& str);

赋值一个自定义字符串类型

	string s1("Hello world!");
	string s2;
	s2 = s1;

(2)c-string

string& operator= (const char* s);

赋值一个字符串数组

	string s3;
	s3 = "hello";

(3)character

string& operator= (char c);

赋值一个字符

	string s4;
	s4 = 'h';

遍历string

下面介绍三种遍历string字符串的方式。

下标+[ ]

在这里插入图片描述

  • string::operator[]
  • 获取字符串元素
  • 返回一个在pos位置处的元素

(1) char& operator[] (size_t pos);
(2)const char& operator[] (size_t pos) const;

(1)和(2)分别使用在自定义函数是否存在const限制,防止权限的放大。

遍历string并访问

int main()
{
	string s1("hello world!");
	int size = s1.size();
	for (int i = 0; i < size; ++i)
	{
		cout << s1[i] << " ";
	}
	return 0;
}

遍历string并修改

int main()
{
	string s1("hello world!");
	int size = s1.size();
	for (int i = 0; i < size; ++i)
	{
		s1[i]++;
	}
	cout << s1 << endl;
	return 0;
}

迭代器

在现阶段,迭代器的使用可以类似于指针,后续在使用迭代器时,又可能是指针,也又可能不是指针。
在这里插入图片描述

在C++98中,string类中介绍了4种函数。

在这里插入图片描述

  • string::begin
  • 将迭代器返回至开始
  • 返回迭代器指向的第一个元素的值

(1)iterator begin();
(2)const_iterator begin() const;

  • 防止权限的放大

在这里插入图片描述

  • string::end
  • 将迭代器返回至结束
  • 将迭代器指向最后一个元素的下一个位置的值,即’\0’的值。
  • the past end是一个理论字符,它将跟随字符串的最后一个字符,它不应该被取消引用。
  • 由于被标准库的函数所使用的范围不包括迭代器所指定的元素,这个函数经常被使用在与string::begin结合,去指定包括字符串所有元素的范围。
  • 如果对象是一个空字符串,则返回string::begin相同的值

遍历string并打印

	string s1("Hello world!");
	string::iterator it = s1.begin();
	while (it != s1.end())
	{
		cout << *it << endl;
		++it;
	}

遍历string并修改

	string s1("Hello world!");
	string::iterator it = s1.begin();
	while (it != s1.end())
	{
		(*it)++;
		it++;
	}

范围for

访问字符串并打印

	string s("hello world!");
	for (char ch : s)
	{
		cout << ch << " ";
	}

访问字符串并修改

	string s("hello world!");
	for (char& ch : s)
	{
		++ch;
	}

【注意】在修改字符串时,需要使用引用,是因为范围for在读取s字符串时,是将s的值赋值给ch。

  • 范围for的底层代替为迭代器,下面在汇编角度观察

在这里插入图片描述

  • 一个类只要支持迭代器,就会支持范围for的用法
  • 任何容器都支持迭代器,并且用法是类似。

【总结】iterator提供了一种统一的方式访问和修改容器的数据,迭代器可以和算法很好地配合,算法可以通过迭代器,去处理容器中的数据。

反向迭代器

反向迭代器和迭代器刚好相反

  • rbegin
    在这里插入图片描述
    (1)reverse_iterator rbegin();
    (2)const_reverse_iterator rbegin() const;
  • 返回反向迭代器至反向开始
  • 返回一个反向迭代器的一个点指向字符串的最后一个元素
  • rend
    在这里插入图片描述
    (1) reverse_iterator rend();
    (2)const_reverse_iterator rend() const;
  • 返回反向迭代器至反向结束
  • 返回一个反向迭代器的一个点指向字符串的第一个元素

在这里插入图片描述

使用迭代器同时可以进行字符串的遍历

	string s("hello world!");
	string::reverse_iterator it = s.rbegin();
	//auto it = s.rbgein();
	while (it != s.rend())
	{
		cout << *it << " ";
		++it;
	}

【注意】权限放大与缩小的问题,如果需要迭代的字符串是被const修饰的时候,需要使用的是const修饰的函数,否则会存在权限放大的故障。

capacity

size

在这里插入图片描述

  • 返回字符串的长度
  • size_t size() const;

(1)返回字符串的长度,以字节为单位。
(2)实际字节的数量遵守字符串内容,不一定存储容量相等。
(3)注意字符串在不知道编码的情况下处理字节,可能最终被用于编码包含的字符串。因此,返回值在多字节或者不同长度的元素顺序中可能与实际编码元素的值不同。
(4)string::size 与 string::length 是同义词,返回值相同。

	string s("Hello world!");
	cout << s.size() << endl;

在这里插入图片描述

length

在这里插入图片描述

  • 返回字符串的长度
  • size_t length() const;

内容与string::size基本相似

	string s("hello world!");
	cout << s.length() << endl;

在这里插入图片描述

max_size

在这里插入图片描述

  • 返回字符串的最大长度
  • size_t max_size() const;

(1)返回字符串可以读取到的最大长度
(2)字符串可以读取到的最大的可能长度,是由于已知系统或者库实现限制决定。但是这个对象不保证可以达到这样的长度:它仍然可能无法分配存储在长度无法到达的点上。

	string s1;
	cout << s1.max_size() << endl;
	string s2("hello world!");
	cout << s2.max_size() << endl;

在这里插入图片描述

resize

在这里插入图片描述

  • void resize (size_t n);
  • void resize (size_t n, char c);
  • 调整字符串

(1)将字符串的大小调整为n个字符的长度
(2)当n比当前字符串的长度小,当前值缩短至前n个字符,删除n个字符以外的字符
(3)当n比当前字符串的长度长,通过插入当前内容最后被扩展至n大小的所需要的字符。如果指定c,新元素会被初始化为c的副本,否则它们是值初始化的字符。

	//当n比字符串长度小时
	string s1("hello world!");
	s1.resize(5);
	cout << s1 << endl;
	//当n比字符串长度长时
	string s2("hello world!");
	s2.resize(15);
	cout << s2 << endl;

在这里插入图片描述

	//当n比字符串长度小时
	string s1("hello world!");
	s1.resize(5,'x');
	cout << s1 << endl;
	//当n比字符串长度长时
	string s2("hello world!");
	s2.resize(20,'x');
	cout << s2 << endl;

在这里插入图片描述

capacity

在这里插入图片描述

  • size_t capacity() const;
  • 返回被分配的存储的大小

(1)返回字符串当前分配的存储空间的大小,用字节表示
(2)这个容量不同于字符串的长度。可以与之相等或者更长,当新的元素增加至字符串中时,额外的空间允许对象进行优化操作。
(3)注意,这个容量不假设字符串的长度有限制。当空间被用尽或者需要更多时,对象会自然地扩展。字符串地理论限制是由成员函数max_size决定。
(4)字符串的容量会在任何时候对象修改的时候修改,即使这种修改意味着尺寸的缩小或者容量尚未耗尽。
(5)字符串的容量可以被成员函数reverse明确修改

	string s("hello world!");
	cout << s.capacity() << endl;

在这里插入图片描述
【注意】不同的编译器的底层实现不同,即容量可能会出现不同。

reserve

在这里插入图片描述

  • void reserve (size_t n = 0);
  • 请求更改容量

(1)请求字符串容量适应一个在长度最多n个字符的计划中的改变
(2)如果n大于当前字符串容量,这个函数造成容器将容量增加至n个字符
(3)在其他所有的实例中,它被视为收缩字符串容量的收缩性请求:容器的实现是自由优化的,此外保留字符串的容量大于n
(4)这个函数对字符串的长度没有影响,并且无法改变其内容。

	string s("hello world!");
	cout << s.capacity() << endl;
	s.reserve(20);
	cout << s.capacity() << endl;

在这里插入图片描述

clear

在这里插入图片描述

  • void clear();
  • 清除字符串

(1)清除字符串的容量,将其变成空字符串。

	string s("hello world!");
	s.clear();
	//遍历打印
	for (int i = 0; i < s.size(); ++i)
	{
		cout << s[i] << endl;
	}

在这里插入图片描述

empty

在这里插入图片描述

  • bool empty() const;
  • 判断字符串是否为空

(1)返回字符串是否为空
(2)这个函数没有使用任何方式修改字符串的值。

	string s("hello world!");
	cout << s.empty() << endl;
	s.clear();
	cout << s.empty() << endl;

在这里插入图片描述

【注意】
1.size()与length()方法实现底层原理完全相同,引入size()的原因是为了与其他容器的接口保持一致,一般情况下基本都是使用size()
2.clear()只是将string中的有效字符清空,不改变底层空间大小
3.resize(size_t n)与resize(size_t n,char c)都是将字符串中有效字符个数改变为n个,不同的是,当字符个数增多时,resize(size_t n)会用0来填充多出的元素空间;而resize(size_t n, char c)会用字符c来填充多出的元素空间。
4.resize在改变元素个数时,如果元素个数增多,可能会改变底层容量的大小,如果将元素个数减小,底层空间总大小不会改变。
5.当reserve();如果里面有数据,不会收缩;如果被clear();清理后,可能会收缩。
6.reserve();只会将capacity();改变,而resize();不仅会将改变空间,同时会填充值并初始化。

Element access(元素访问)

operator[ ]

在这里插入图片描述

  • 获取字符串的元素。
  • char& operator[] (size_t pos);
  • const char& operator[] (size_t pos) const;
  • 返回一个在pos位置处的元素

at

在这里插入图片描述

  • char& at (size_t pos);
  • const char& at (size_t pos) const;
  • 在字符串中获取元素
  • 返回一个字符串中pos位置的参考元素。
  • 这个函数会自动检查在字符冲中pos位置是否为元素的有效位置(如果越界会抛异常)
	string s1("hello world");
	s1.at(1) = 'x';
	cout << s1 << endl;

【注意】使用operator[]与at()基本相同,但是需要注意的是如果operator[]越界访问会被断言,ar()会出现抛异常。

Modifiers(字符串进行修改)

operator+=

在这里插入图片描述

  • string (1)
    string& operator+= (const string& str);

+=一个字符串

	string s1("hello");
	s1 += "world";
	cout << s1 << endl;
  • c-string (2)
    string& operator+= (const char* s);

+=一个只读字符

	string s1("hello");
	s1 += 'x';
	cout << s1 << endl;
  • character (3)
    string& operator+= (char c);

+=一个元素

	string s1("hello");
	char c = 'm';
	s1 += c;
	cout << s1 << endl;
  • 字符串附加
  • 在当前值的末尾通过其他字符扩展字符串

append

在这里插入图片描述

  • string (1)
    string& append (const string& str);

string:附加一个str的副本

	string s1("hello");
	s1.append("world");
	cout << s1 << endl;
  • substring (2)
    string& append (const string& str, size_t subpos, size_t sublen);

substring:附加一个str的子字符串的副本。这个子字符串是str的一部分,在元素位置subpos开始,间隔sublen个元素个数。

	string s1("hello");
	s1.append("world", 2, 3);
	cout << s1 << endl;
  • c-string (3)
    string& append (const char* s);

c-string:附加一个由s指向以null结尾字符串序列形成的字符串的副本。

	string s1("hello");
	s1.append("world");
	cout << s1 << endl;
  • buffer (4)
    string& append (const char* s, size_t n);

buffer:附加一个由s指向元素位置的前n个元素的副本。

	string s1("hello");
	s1.append("world", 3);
	cout << s1 << endl;
  • fill (5)
    string& append (size_t n, char c);

fill:附加那个连续的字符c的副本

	string s1("hello");
	s1.append(5,'x');
	cout << s1 << endl;
  • range (6)
    template < class InputIterator>
    string& append (InputIterator first, InputIterator last);

initializer list(初始值设定项列表):按照相同的顺序附加 il 中每一个字符的副本。

push_back

在这里插入图片描述

  • void push_back (char c);
  • 附加元素到附加元素c到字符串末尾,将其长度加一
	string s1("hello");
	s1.push_back('x');
	cout << s1 << endl;

assign

在这里插入图片描述

【注意】分配一个新内容到字符串,取代当前内容

  • string (1)
    string& assign (const string& str);

string:拷贝字符串

	string s1("hello");
	s1.assign("world");
	cout << s1 << endl;
  • substring (2)
    string& assign (const string& str, size_t subpos, size_t sublen);

substring:拷贝str的一部分,在subpos元素位置开始,间隔sublen个元素

	string s1("hello world");
	s1.assign("world", 3, 2);
	cout << s1 << endl;
  • c-string (3)
    string& assign (const char* s);

c-string:拷贝s指向的以null结束的元素列表

	string s1("hello");
	s1.assign("world");
	cout << s1 << endl;
  • buffer (4)
    string& assign (const char* s, size_t n);

buffer:拷贝s指向的元素数组的前n个元素

	string s1("hello");
	s1.assign("world", 2);
	cout << s1 << endl;
  • fill (5)
    string& assign (size_t n, char c);

fill:被n个连续的字符c的拷贝代替当前的值

	string s1("hello world");
	s1.assign(5, 'x');
	cout << s1 << endl;
  • range (6)
    template < class InputIterator>
    string& assign (InputIterator first, InputIterator last);

range:使用相同的顺序在范围内拷贝元素顺序。

insert

在这里插入图片描述

std::string::insert
【注意】在pos指示的位置之前插入附加的元素到字符串中。

  • string (1)
    string& insert (size_t pos, const string& str);

string:插入str的拷贝

	string s1("hello");
	s1.insert(5, "world");
	cout << s1 << endl;
  • substring (2)
    string& insert (size_t pos, const string& str, size_t subpos, size_t sublen);

substring:插入str的子字符串的拷贝,这个子字符串是str的一部风,在subpos元素位置开始,间隔sublen个元素

	string s1("hello");
	s1.insert(1, "world", 3, 2);
	cout << s1 << endl;
  • c-string (3)
    string& insert (size_t pos, const char* s);

c-string:插入由s指向以null结束的字符列表形成的字符串的一个拷贝

	string s1("hello");
	s1.insert(5, "world");
	cout << s1 << endl;
  • buffer (4)
    string& insert (size_t pos, const char* s, size_t n);

buffer:插入由s指向数组中的元素的前n个元素的拷贝

	string s1("hello");
	s1.insert(2, "world", 3);
	cout << s1 << endl;
  • fill (5)
    string& insert (size_t pos, size_t n, char c);
    void insert (iterator p, size_t n, char c);

fill:插入n个连续的字符c的拷贝

	string s1("hello");
	s1.insert(2, 3,'x');
	cout << s1 << endl;
  • single character (6)
    iterator insert (iterator p, char c);

single character:插入字符c

	string s1("hello");
	s1.insert(s1.begin() + 1, 'x');
	cout << s1 << endl;
  • range (7)
    template < class InputIterator>
    void insert (iterator p, InputIterator first, InputIterator last);

range:使用相同的顺序在范围内拷贝元素顺序

【注意】size_t是无符号整数类型

erase

在这里插入图片描述

  • std::string::erase

  • 擦除字符串中的元素

  • 擦除部分字符串,缩减其长度

  • sequence (1)
    string& erase (size_t pos = 0, size_t len = npos);

sequence:擦除字符串的部分值,这个值开始于pos位置,间隔len长度

	string s1("hello");
	s1.erase(2, 2);
	cout << s1 << endl;
  • character (2)
    iterator erase (iterator p);

character:擦除指向p的元素

	string s1("hello");
	s1.erase(s1.begin() + 1);
	cout << s1 << endl;

replace

在这里插入图片描述

  • std::string::replace
  • 取代部分字符串
  • 取代部分字符串,开始于pos位置,间隔len个元素

swap

在这里插入图片描述

  • std::string::swap
  • void swap (string& str);
  • 交换字符串的值

String operations(字符串进行操作)

c_str

在这里插入图片描述

  • std::string::c_str
  • const char* c_str() const;
  • 获取等效的c字符串
  • 返回一个指针指向一个包含null结束的字符序列的数组,代表当前字符串的值。
  • 此数组包含相同的字符序列,将string对象的值加上末尾的附加终止null字符(‘\0’)组成
  • 程序不得更改序列中的任何字符
  • 返回的指针可能会因进一步调用修改对象的其他成员函数而失效

【注意】c_str();是为了让c的一些接口函数配合

	string s1("hello");
	cout << s1.c_str() << endl;

copy

在这里插入图片描述

  • std::string::copy
  • size_t copy (char* s, size_t len, size_t pos = 0) const;
  • 从字符串中拷贝字符序列

find

在这里插入图片描述

  • std::string::find
  • 在字符串中查找内容
	string ur1 = "https://editor.csdn.net/md?articleId=139749504";
	size_t pos1 = ur1.find("://");
	string protocal;//协议
	if (pos1 != string::npos)
	{
		protocal = ur1.substr(0, pos1);
	}
	string domain;//域名
	string resource;//资源名
	size_t pos2 = ur1.find('/', pos1 + 3);
	if (pos2 != string::npos)
	{
		domain = ur1.substr(pos1 + 3, pos2 - (pos1 + 3));
		resource = ur1.substr(pos2 + 1);//
	}
	cout << protocal << endl;
	cout << domain << endl;
	cout <<resource << endl;

rfind

在这里插入图片描述

  • std::string::rfind
  • 寻找在字符串最后发生的内容
  • 寻找由其参数指定的序列的字符串最后发生的内容

find_first_of

在这里插入图片描述

  • std::string::find_first_of
  • 查找字符串中的元素
  • 寻找字符串中的第一个元素,匹配其参数中指定的任何字符
	string s1("Searches the string for the first character that matches any of the characters specified in its arguments.");
	size_t found = s1.find_first_of("abc");
	while (found != string::npos)
	{
		s1[found] = '*';
		found = s1.find_first_of("abc", found + 1);
	}
	cout << s1 << endl;

find_last_of

在这里插入图片描述

  • std::string::find_last_of
  • 从后面开始在字符串中寻找字符

find_first_not_of

在这里插入图片描述

  • std::string::find_first_not_of
  • 在字符串中查找缺席的字符

find_last_not_of

在这里插入图片描述

  • std::string::find_last_not_of
  • 从后面开始查找在字符串中不匹配的字符

substr

在这里插入图片描述

  • std::string::substr
  • 生成子字符串

compare

在这里插入图片描述

  • std::string::compare
  • 比较俩个字符串

【注意】
1.在str尾部追加字符时,s.push_back©/s.append(1,c)/s += 'x’三种实现方式基本差不多,一般情况下string类的+=操作使用较多,+=不仅可以连接单个字符,同时也可以连接字符串。
2.对string进行操作时,如果能够预估到多少字符,可以使用reserve把空间预留好。

Member constants(成员常量)

npos

在这里插入图片描述

  • std::string::npos
  • size_t的最大值

Non-member function overloads(非成员函数重载)

operator+ (string)

在这里插入图片描述

  • std::operator+ (string)
  • 连接字符串

relational operators (string)

在这里插入图片描述

  • relational operators (string)
  • 字符串的关系运算符

swap (string)

在这里插入图片描述

  • std::swap (string)
  • 交换俩个字符串的值

operator>> (string)

在这里插入图片描述

  • std::operator>> (string)
  • 从流中提取字符串

operator<< (string)

在这里插入图片描述

  • std::operator<< (string)
  • 将字符串插入流中

getline (string)

在这里插入图片描述

  • std::getline (string)
  • 获取流中的全部字符串

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Outlook发送大文件的问题是什么?怎么解决?

Outlook不仅是一款电子邮件客户端&#xff0c;还包括日历、任务、笔记、联系人等功能&#xff0c;同时与Microsoft Office套件中的其他应用程序&#xff08;如Word、Excel、PowerPoint等&#xff09;集成紧密&#xff0c;方便用户在不同应用程序之间切换&#xff0c;提高工作效…

TC3xx NvM小细节解读

目录 1.FlsLoader Driver和FlsDmu Driver 2. FlsLoader小细节 3.小结 大家好&#xff0c;我是快乐的肌肉&#xff0c;今天聊聊TC3xx NvM相关硬件细节以及MCAL针对NvM的驱动。 1.FlsLoader Driver和FlsDmu Driver 在最开始做标定的时候&#xff0c;认为标定数据既然是数据&…

力扣双指针算法题目:复写零

1.题目 . - 力扣&#xff08;LeetCode&#xff09; 2.解题思路 本题要求就是对于一个数组顺序表&#xff0c;将表中的所有“0”元素都向后再写一遍&#xff0c;且我们还要保证此元素之后的元素不受到影响&#xff0c;且复写零之后此数组顺序表的总长度不可以改变&#xff0c;…

C#(asp.net)房屋租赁管理系统-计算机毕业设计源码64421

目 录 摘要 1 绪论 1.1 研究背景与意义 1.2开发现状 1.3论文结构与章节安排 2 房屋租赁管理系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统用例分析 …

如何利用好用便签提高工作效率?

在忙碌的工作中&#xff0c;我们经常需要记住许多琐碎的任务。如果这些任务被遗忘&#xff0c;可能会对我们的工作产生影响。这时&#xff0c;便签就成为了我们的得力助手。通过合理的使用和管理&#xff0c;便签不仅能帮助我们记住重要的事项&#xff0c;还能提高我们的工作效…

中科蓝讯AB5607E蓝牙5.4 低成本带插卡带U盘音箱方案

方案概述 中科蓝讯AB5607E蓝牙5.4 低成本带插卡带U盘音箱方案&#xff0c;我们已有成熟的方案&#xff0c;用户可以免开发&#xff08;零代码&#xff09;快速完成带插卡带U盘蓝牙音箱&#xff0c;提供原理图&#xff0c;PCB Layout指导。 方案优势 低成本&#xff0c;IC成本低…

【Linux进程】进程优先级 Linux 2.6内核进程的调度

前言 进程是资源分配的基本单位, 在OS中存在这很多的进程, 那么就必然存在着资源竞争的问题, 操作系统是如何进行资源分配的? 对于多个进程同时运行, 操作系统又是如何调度达到并发呢? 本文将以Linux kernel 2.6为例 , 向大家介绍进程在操作系统中 (OS) 的调度原理; 1. 进程优…

【开发工具-前端必备神器】WebStrom2024版-安装和使用(小白学习)

一、官方下载地址 Other Versions - WebStorm 选择适合自己电脑的下载 二、安装步骤 1、双击下载的exe安装 2、选择安装目录【建议不要安装在C盘下】 3、安装选项&#xff0c;可以全选 4一直点击下一步就行了 5.双击运行 安装遇到问题&#xff1a; 我是下错版本了&#xff0…

Motion Guidance: 扩散模型实现图像精确编辑的创新方法

在深度学习领域&#xff0c;扩散模型&#xff08;diffusion models&#xff09;因其能够根据文本描述生成高质量图像而备受关注。然而&#xff0c;这些模型在精确编辑图像中对象的布局、位置、姿态和形状方面仍存在挑战。本文提出了一种名为“运动引导”&#xff08;motion gui…

【LLM】一、利用ollama本地部署大模型

目录 前言 一、Ollama 简介 1、什么是Ollama 2、特点&#xff1a; 二、Windows部署 1.下载 2.安装 3.测试安装 4.模型部署&#xff1a; 5.注意 三、 Docker部署 1.docker安装 2.ollama镜像拉取 3.ollama运行容器 4.模型部署&#xff1a; 5.注意&#xff1a; 总结 前言…

【C++】哈希表 ---开散列版本的实现

你很自由 充满了无限可能 这是很棒的事 我衷心祈祷你可以相信自己 无悔地燃烧自己的人生 -- 东野圭吾 《解忧杂货店》 开散列版本的实现 1 前言2 开散列版本的实现2.1 节点设计2.2 框架搭建2.3 插入函数2.4 删除函数2.5 查找操作2.6 测试 Thanks♪(&#xff65;ω&#x…

OpenCV 灰度直方图及熵的计算

目录 一、概述 1.1灰度直方图 1.1.1灰度直方图的原理 1.1.2灰度直方图的应用 1.1.3直方图的评判标准 1.2熵 二、代码实现 三、实现效果 3.1直方图显示 3.2 熵的计算 一、概述 OpenCV中的灰度直方图是一个关键的工具&#xff0c;用于分析和理解图像的灰度分布情况。直…

Excel多表格合并

我这里一共有25张表格: 所有表的表头和格式都一样,但是内容不一样: 现在我要做的是把所有表格的内容合并到一起,研究了一下发现WPS的这项功能要开会员的,本来想用代码撸出来的,但是后来想想还是找其他办法,后来找到"易用宝"这个插件,这个插件可以从如下地址下载:ht…

图像处理中的二维傅里叶变换

图像处理中的二维傅里叶变换 问题来源是对彩色图像进行压缩时得出的傅里叶系数的图像如何解释&#xff0c;导入图片&#xff0c;转化为灰度图片&#xff1a; #彩色图片一般是由RGB组成&#xff0c;其实就是3个二维数组叠加而成&#xff0c;当RGB时&#xff0c;彩色图片就会变成…

【线性代数的本质】矩阵与线性变换

线性变化要满足两点性质&#xff1a; 直线&#xff08;连续的点&#xff09;在变换后还是直线。原点不变。 假设有坐标轴&#xff08;基底&#xff09; i ^ \widehat{i} i 和 j ^ \widehat{j} j ​&#xff1a; i ^ [ 1 0 ] , j ^ [ 0 1 ] \widehat{i}\begin{bmatrix} 1 \…

【leetcode】双指针算法题

文章目录 1.算法思想2.移动零3.复写零方法一方法二 4.快乐数5.盛水最多的容器方法一&#xff08;暴力求解&#xff09;方法二&#xff08;左右指针&#xff09; 6.有效三角形的个数方法一&#xff08;暴力求解&#xff09;方法二&#xff08;左右指针&#xff09; 7.两数之和8.…

ONLYOFFICE 8.1版本震撼来袭,让办公更高效、更智能

官网链接&#xff1a; 在线PDF查看器和转换器 | ONLYOFFICE 在线办公套件 | ONLYOFFICE 随着科技的不断发展&#xff0c;办公软件已经成为现代企业提高工作效率、实现信息共享的重要工具。在我国&#xff0c;一款名为ONLYOFFICE的在线办公套件受到了越来越多企业的青睐。今天…

Prompt-Free Diffusion: Taking “Text” out of Text-to-Image Diffusion Models

CVPR2024 SHI Labshttps://arxiv.org/pdf/2305.16223https://github.com/SHI-Labs/Prompt-Free-Diffusion 问题引入 在SD模型的基础之上&#xff0c;去掉text prompt&#xff0c;使用reference image作为生成图片语义的指导&#xff0c;optional structure image作为生成图片…

深入理解【 String类】

目录 1、String类的重要性 2、常用方法 2、1 字符串构造 2、2 String对象的比较 2、3 字符串查找 2、4字符转换 数值和字符串转换&#xff1a; 大小写转化&#xff1a; 字符串转数组&#xff1a; 格式转化&#xff1a; 2、5 字符串替换 2、6字符串拆分 2、7 字符串…

知名品牌因商标痛失市场:114家直营店山寨店7000多家!

奶茶知名品牌“鹿角巷”当年红遍大江南北&#xff0c;是最早的新茶饮品牌&#xff0c;但是当年商标注册存在问题&#xff0c;被同行奶茶品牌抢占了先机&#xff0c;发声明“对大陆商标注册细则不详&#xff0c;在商标注册过程中让假店钻了法律空档”&#xff0c;最夸张的时候全…