c++复习要点总结z之十二——STL string
1String概念
² string是STL的字符串类型,通常用来表示字符串。而在使用string之前,字符串通常是用char*表示的。string与char*都可以用来表示字符串,那么二者有什么区别呢。
string和char*的比较
² string是一个类, char*是一个指向字符的指针。
string封装了char*,管理这个字符串,是一个char*型的容器。
² string不用考虑内存释放和越界。
string管理char*所分配的内存。每一次string的复制,取值都由string类负责维护,不用担心复制越界和取值越界等。
² string提供了一系列的字符串操作函数(这个等下会详讲)
查找find,拷贝copy,删除erase,替换replace,插入insert
2string的构造函数
² 默认构造函数:
string(); //构造一个空的字符串string s1。
² 拷贝构造函数:
string(const string &str); //构造一个与str一样的string。如strings1(s2)。
² 带参数的构造函数
string(const char *s); //用字符串s初始化
string(int n,char c); //用n个字符c初始化
3string的存取字符操作
² string类的字符操作:
const char &operator[] (int n) const; const char &at(int n) const; char &operator[] (int n); char &at(int n);
² operator[]和at()均返回当前字符串中第n个字符,但二者是有区别的。
主要区别在于at()在越界时会抛出异常,[]在刚好越界时会返回(char)0,再继续越界时,编译器直接出错。如果你的程序希望可以通过try,catch捕获异常,建议采用at()。
4从string取得const char*的操作
² const char *c_str() const; //返回一个以'\0'结尾的字符串的首地址
5把string拷贝到char*指向的内存空间的操作
² int copy(char *s, int n, int pos=0) const;
把当前串中以pos开始的n个字符拷贝到以s为起始位置的字符数组中,返回实际拷贝的数目。注意要保证s所指向的空间足够大以容纳当前字符串,不然会越界。
6string的长度
int length() const; //返回当前字符串的长度。长度不包括字符串结尾的'\0'。
bool empty() const; //当前字符串是否为空
7string的赋值
string &operator=(const string&s);//把字符串s赋给当前的字符串 string &assign(const char *s); //把字符串s赋给当前的字符串 string &assign(const char *s, int n);//把字符串s的前n个字符赋给当前的字符串 string &assign(const string&s); //把字符串s赋给当前字符串 string &assign(int n,char c); //用n个字符c赋给当前字符串 string &assign(const string &s,intstart, int n); //把字符串s中从start开始的n个字符赋给当前字符串
8string字符串连接
string &operator+=(const string&s); //把字符串s连接到当前字符串结尾 string &operator+=(const char *s);//把字符串s连接到当前字符串结尾 string &append(const char *s); //把字符串s连接到当前字符串结尾 string &append(const char *s,intn); //把字符串s的前n个字符连接到当前字符串结尾 string &append(const string&s); //同operator+=() string &append(const string &s,intpos, int n);//把字符串s中从pos开始的n个字符连接到当前字符串结尾 string &append(int n, char c); //在当前字符串结尾添加n个字符c
9string的比较
int compare(const string &s)const; //与字符串s比较 int compare(const char *s) const; //与字符串s比较 compare函数在>时返回 1,<时返回 -1,==时返回 0。比较区分大小写,比较时参考字典顺序,排越前面的越小。大写的A比小写的a小。
10string的子串
string substr(int pos=0, int n=npos)const; //返回由pos开始的n个字符组成的子字符串
11string的查找和 替换
查找
int find(char c,int pos=0) const; //从pos开始查找字符c在当前字符串的位置 int find(const char *s, int pos=0)const; //从pos开始查找字符串s在当前字符串的位置 int find(const string &s, int pos=0)const; //从pos开始查找字符串s在当前字符串中的位置 find函数如果查找不到,就返回-1 int rfind(char c, int pos=npos) const; //从pos开始从后向前查找字符c在当前字符串中的位置 int rfind(const char *s, int pos=npos)const; int rfind(const string &s, intpos=npos) const; //rfind是反向查找的意思,如果查找不到, 返回-1
替换
string &replace(int pos, int n, constchar *s);//删除从pos开始的n个字符,然后在pos处插入串s string &replace(int pos, int n, conststring &s); //删除从pos开始的n个字符,然后在pos处插入串s void swap(string &s2); //交换当前字符串与s2的值 //4 字符串的查找和替换 void main25() { strings1 = "wbm hello wbm 111 wbm 222 wbm 333"; size_tindex = s1.find("wbm", 0); cout<< "index: " << index; //求itcast出现的次数 size_toffindex = s1.find("wbm", 0); while(offindex != string::npos) { cout<< "在下标index: " << offindex << "找到wbm\n"; offindex= offindex + 1; offindex= s1.find("wbm", offindex); } //替换 strings2 = "wbm hello wbm 111 wbm 222 wbm 333"; s2.replace(0,3, "wbm"); cout<< s2 << endl; //求itcast出现的次数 offindex= s2.find("wbm", 0); while(offindex != string::npos) { cout<< "在下标index: " << offindex << "找到wbm\n"; s2.replace(offindex,3, "WBM"); offindex= offindex + 1; offindex= s1.find("wbm", offindex); } cout<< "替换以后的s2:" << s2 << endl; }
12String的区间删除和插入
string &insert(int pos, const char *s); string &insert(int pos, const string&s); //前两个函数在pos位置插入字符串s string &insert(int pos, int n, charc); //在pos位置 插入n个字符c string &erase(int pos=0, intn=npos); //删除pos开始的n个字符,返回修改后的字符串
13string算法相关
void main27() { strings2 = "AAAbbb"; transform(s2.begin(),s2.end(), s2.begin(), toupper); cout<< s2 << endl; strings3 = "AAAbbb"; transform(s3.begin(),s3.end(), s3.begin(), tolower); cout<< s3 << endl; }
以上就是c++复习要点总结z之十二——STL string的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Langkah-langkah untuk melaksanakan corak strategi dalam C++ adalah seperti berikut: tentukan antara muka strategi dan isytiharkan kaedah yang perlu dilaksanakan. Buat kelas strategi khusus, laksanakan antara muka masing-masing dan sediakan algoritma yang berbeza. Gunakan kelas konteks untuk memegang rujukan kepada kelas strategi konkrit dan melaksanakan operasi melaluinya.

Pengendalian pengecualian bersarang dilaksanakan dalam C++ melalui blok try-catch bersarang, membenarkan pengecualian baharu dibangkitkan dalam pengendali pengecualian. Langkah-langkah cuba-tangkap bersarang adalah seperti berikut: 1. Blok cuba-tangkap luar mengendalikan semua pengecualian, termasuk yang dilemparkan oleh pengendali pengecualian dalam. 2. Blok cuba-tangkap dalam mengendalikan jenis pengecualian tertentu, dan jika pengecualian luar skop berlaku, kawalan diberikan kepada pengendali pengecualian luaran.

Warisan templat C++ membenarkan kelas terbitan templat menggunakan semula kod dan kefungsian templat kelas asas, yang sesuai untuk mencipta kelas dengan logik teras yang sama tetapi gelagat khusus yang berbeza. Sintaks warisan templat ialah: templateclassDerived:publicBase{}. Contoh: templateclassBase{};templateclassDerived:publicBase{};. Kes praktikal: Mencipta kelas terbitan Derived, mewarisi fungsi mengira Base kelas asas, dan menambah kaedah printCount untuk mencetak kiraan semasa.

Punca dan penyelesaian untuk kesilapan Apabila menggunakan PECL untuk memasang sambungan dalam persekitaran Docker Apabila menggunakan persekitaran Docker, kami sering menemui beberapa sakit kepala ...

Dalam C, jenis char digunakan dalam rentetan: 1. Simpan satu watak; 2. Gunakan array untuk mewakili rentetan dan berakhir dengan terminator null; 3. Beroperasi melalui fungsi operasi rentetan; 4. Baca atau output rentetan dari papan kekunci.

Dalam C++ berbilang benang, pengendalian pengecualian dilaksanakan melalui mekanisme std::promise dan std::future: gunakan objek promise untuk merekodkan pengecualian dalam utas yang membuang pengecualian. Gunakan objek masa hadapan untuk menyemak pengecualian dalam urutan yang menerima pengecualian. Kes praktikal menunjukkan cara menggunakan janji dan niaga hadapan untuk menangkap dan mengendalikan pengecualian dalam urutan yang berbeza.

Multithreading dalam bahasa dapat meningkatkan kecekapan program. Terdapat empat cara utama untuk melaksanakan multithreading dalam bahasa C: Buat proses bebas: Buat pelbagai proses berjalan secara bebas, setiap proses mempunyai ruang ingatan sendiri. Pseudo-Multithreading: Buat pelbagai aliran pelaksanaan dalam proses yang berkongsi ruang memori yang sama dan laksanakan secara bergantian. Perpustakaan multi-threaded: Gunakan perpustakaan berbilang threaded seperti PTHREADS untuk membuat dan mengurus benang, menyediakan fungsi operasi benang yang kaya. Coroutine: Pelaksanaan pelbagai threaded ringan yang membahagikan tugas menjadi subtask kecil dan melaksanakannya pada gilirannya.

Pengiraan C35 pada dasarnya adalah matematik gabungan, yang mewakili bilangan kombinasi yang dipilih dari 3 dari 5 elemen. Formula pengiraan ialah C53 = 5! / (3! * 2!), Yang boleh dikira secara langsung oleh gelung untuk meningkatkan kecekapan dan mengelakkan limpahan. Di samping itu, memahami sifat kombinasi dan menguasai kaedah pengiraan yang cekap adalah penting untuk menyelesaikan banyak masalah dalam bidang statistik kebarangkalian, kriptografi, reka bentuk algoritma, dll.
