• STL - string


    string概念

            1.string是STL的字符串类型,通常用来表示字符串

             使用string之前,字符串通常是用char *表示的。string与char *都可以用来表示字符串。

            2.string是一个类,char *是一个指向字符的指针

             string封装了char *,管理这个字符串,是一个char *型的容器。

            3.string不用考虑内存释放和越界

             string管理char *所分配的内存。每一次string的复制,取值都由string类负责维护,不用担心复制越界和取值越界等

            4.string提供了一系列的字符串操作函数

              查找 find  拷贝copy 删除erase 替换replace 插入insert

     string的构造函数

            默认构造函数:

                    string()                                           //构造一个空字符串  string s1

            拷贝构造函数:

                    string(const string &str);                //构造一个与str一样的string

            带参数的构造函数:

                    string(const char *);                        //用字符串s初始化

                    string(int n,char c);                         //用n个字符c初始化

    string的存取字符操作

     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()

    从string取得const char*的操作

             const char*c_str()  const;                返回一个以‘\0’结尾的字符串的首地址

    把string拷贝到char *指向的内存空间的操作

            int copy(char *s,int n,int pos=0)const;   

            把当前串以pos开始的n个字符拷贝到以s为起始位置的字符数组中,返回实际拷贝的数目。注意要保证s所指向的空间足够大以容纳当前字符串,不然会越界。

    string的长度

    int length() const;                 //返回当前字符串的长度。长度不包括字符串结尾的‘\0’

    bool empty()const;               //当前字符串是否为空

    string的赋值 

    string &operator=(const string &s);        //把字符串s赋值给当前的字符串

    string &assign(const char *s);                //把字符串s赋值给当前的字符串

    string &assign(const string &s,int n);     //把字符串s的前n个字符赋给当前字符串

    string &assign(const string &s);             //把字符串s赋给当前字符串

    string &assign(int n,char c);                   //用n个字符c赋值给当前字符

    string &assign(const string &s,int start,int n);//把字符串s中从start开始n个字符赋给当前字符

    string字符串连接 

    string &operator+=(const string &s);

    string &operator+=(const char *s);

    string &append(const char*s,int n);

    string &append(const string &s);

    string &append(const string &s,int pos,int n);

    string &append(int n,char c);

    string的比较  

    int  compare(const string &s)const;

    int  compare(const char *s)const;

    string的查找和替换 

    int find(char a,int pos=0)const;

    int find(const char*s,int pos=0)const;

    int find(const string &s,int pos=0)const;

    int rfind(const char*s,int pos=npos)const;

    int rfind(const string&s,int pos=npos)const;

    string &replace(int pos,int n,const char *s);

    string &replace(int pos,int n,const string *s);

    void swap(string &s2);

    string的区间删除和插入

    string &insert(int pos,const char *s);

    string &insert(int pos,const string &s);

    string &insert(int pos,int n,char c);

    string &erase(int pos=0,int n=npos);

    string大小写转换

    transform(InputIterator first1,Inputerator last,OutputIterator result,OP);

  • 相关阅读:
    I.MX6U-驱动开发-4-linux设备树
    docker版jxTMS使用指南:使用webSocket
    【数据结构】优先级队列(堆)
    个性化实时音乐推荐系统-毕业设计
    有关GPU主机的一些故障
    Git和SVN有什么区别?
    软件架构思想和系统架构图
    lua脚本实现redis分布式锁(脚本解析)
    玩转Makefile文件
    1230天,百度再见!!!
  • 原文地址:https://blog.csdn.net/weixin_46120107/article/details/126111082