将一个char类型字符添加到string的尾部的方法---C++

简介: 将一个char类型字符添加到string的尾部的方法---C++

1. += 简单粗暴的方法


std::string s("hello");
  const char c = 'N';//将要加到s后面的字符
  s += c;
  std::cout << s << std::endl;
  return 0;

在string内部对于+=这个操作符是重新写了的,如下, push_back其实就是往尾部增加一个字符,那这样看来,直接调用push_back岂不是更高效?

_CONSTEXPR20 basic_string& operator+=(_Elem _Ch) {
        push_back(_Ch);
        return *this;
    }


2. string内置方法push_back


std::string s("hello");
  const char c = 'N';//将要加到s后面的字符
  //s += c;
  s.push_back(c);
  std::cout << s << std::endl;

我们来看看push_back内部是如何实现的:

_CONSTEXPR20 void push_back(const _Elem _Ch) { // insert element at end
        const size_type _Old_size = _Mypair._Myval2._Mysize;
        if (_Old_size < _Mypair._Myval2._Myres) {
            _Mypair._Myval2._Mysize = _Old_size + 1;
            _Elem* const _Ptr       = _Mypair._Myval2._Myptr();
            _Traits::assign(_Ptr[_Old_size], _Ch);
            _Traits::assign(_Ptr[_Old_size + 1], _Elem());
            return;
        }
        _Reallocate_grow_by(
            1,
            [](_Elem* const _New_ptr, const _Elem* const _Old_ptr, const size_type _Old_size, const _Elem _Ch) {
                _Traits::copy(_New_ptr, _Old_ptr, _Old_size);
                _Traits::assign(_New_ptr[_Old_size], _Ch);
                _Traits::assign(_New_ptr[_Old_size + 1], _Elem());
            },
            _Ch);
    }


3. string内置方法insert


std::string s("hello");
  const char c = 'N';//将要加到s后面的字符
  //s += c;
  //s.push_back(c);
  s.insert(s.length(), 1, c);
  std::cout << s << std::endl;

以上这段代码的意思,就是往string的尾部,插入一个字符c,insert三参数。


4. string内置方法append


std::string s("hello");
  const char c = 'N';//将要加到s后面的字符
  //s += c;
  //s.push_back(c);
  //s.insert(s.length(), 1, c);
  s.append(1, c);
  std::cout << s << std::endl;

那么看看append是如何实现的,和push_back有啥区别,其实仔细阅读两段代码是非常相似的,只是把append中的参数count替换成1,就是push_back的实现了

_CONSTEXPR20 basic_string& append(_CRT_GUARDOVERFLOW const size_type _Count, const _Elem _Ch) {
        // append _Count * _Ch
        const size_type _Old_size = _Mypair._Myval2._Mysize;
        if (_Count <= _Mypair._Myval2._Myres - _Old_size) {
            _Mypair._Myval2._Mysize = _Old_size + _Count;
            _Elem* const _Old_ptr   = _Mypair._Myval2._Myptr();
            _Traits::assign(_Old_ptr + _Old_size, _Count, _Ch);
            _Traits::assign(_Old_ptr[_Old_size + _Count], _Elem());
            return *this;
        }
        return _Reallocate_grow_by(
            _Count,
            [](_Elem* const _New_ptr, const _Elem* const _Old_ptr, const size_type _Old_size, const size_type _Count,
                const _Elem _Ch) {
                _Traits::copy(_New_ptr, _Old_ptr, _Old_size);
                _Traits::assign(_New_ptr + _Old_size, _Count, _Ch);
                _Traits::assign(_New_ptr[_Old_size + _Count], _Elem());
            },
            _Count, _Ch);
    }


5. 使用流的方式来操作,方式稍微有点怪,但也不难理解


#include <iostream>
#include <sstream>
int main() {
  std::string s("hello");
  const char c = 'N';//将要加到s后面的字符
  //s += c;
  //s.push_back(c);
  //s.insert(s.length(), 1, c);
  //s.append(1, c);
  std::stringstream ts;
  ts << s << c;//将字符串s和字符c输入到临时字符串流ts中
  ts >> s;//ts将自己内部保存的值,反吐给s
  std::cout << s << std::endl;
  return 0;
}
目录
相关文章
|
5天前
|
安全 C++
C++一分钟之-字符串处理:std::string
【6月更文挑战第25天】`std::string`是C++文本处理的核心,存在于`&lt;string&gt;`库中。它支持初始化、访问、连接、查找、替换等操作。常见问题包括空指针解引用、越界访问和不当内存管理。要安全使用,确保字符串初始化,用`at()`检查边界,用`.empty()`检查空字符串,且无需手动释放内存。高效技巧包括预先分配内存、利用互转函数以及使用迭代器。记得正确比较和遍历字符串以保证代码效率和安全性。
24 5
|
4天前
|
C++ 容器
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
C++字符串string容器(构造、赋值、拼接、查找、替换、比较、存取、插入、删除、子串)
12 1
|
3天前
详细解读C++char类型函数
详细解读C++char类型函数
|
3天前
|
C语言 C++
【c++】string模拟实现(2)
【c++】string模拟实现(2)
7 0
|
3天前
|
算法 C++
【c++】string模拟实现(1)
【c++】string模拟实现(1)
7 0
|
4天前
|
存储 编译器 C语言
【C++航海王:追寻罗杰的编程之路】string类
【C++航海王:追寻罗杰的编程之路】string类
7 0
|
4天前
|
编译器 C++
【C++】学习笔记——string_5
【C++】学习笔记——string_5
6 0
|
4天前
|
编译器 C语言 C++
【C++】学习笔记——string_4
【C++】学习笔记——string_4
7 0
|
4天前
|
C语言 C++
【C++】学习笔记——string_3
【C++】学习笔记——string_3
8 0
|
4天前
|
存储 编译器 C++
【C++】学习笔记——string_2
【C++】学习笔记——string_2
11 0