1. string的定义原型

    typedef basic_string<char, char_traits<char>, allocator<char> >
    string;
    typedef basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t> >
    wstring; // 第二三个参数有默认值

  2. string部分构造方式
    // string 部分构造方式
    #include <iostream>
    #include <string>
    using namespace std; int main(void)
    {
    string s1;
    string s2("ABCDEFG");
    cout << s1 << endl;
    cout << s2 << endl; // 使用最初的形式定义
    basic_string<char> s3("xxxx");
    cout << s3 << endl; /*
    basic_string(
    const value_type *_Ptr,
    size_type _Count
    );
    */
    string s4("DEFG", 2);
    cout << s4 << endl; // DE
    /*
    basic_string(
    const basic_string& _Right,
    size_type _Roff,
    size_type _Count = npos
    );
    */
    string s5(s2, 2, 2);
    cout << s5 << endl; //CD /*
    basic_string(
    const_iterator _First,
    const_iterator _Last
    );
    */
    string::const_iterator first = s2.begin() + 1;
    string::const_iterator end = s2.begin() + 3; // [first, end)
    string s6(first, end);
    cout << s6 << endl; // BC return 0;
    }

  3. string常用成员函数
    // string 部分成员函数部分形式操作
    #include <iostream>
    #include <string>
    using namespace std; int main(void)
    {
    string s1("ABCDEC");
    cout << s1.size() << endl;
    cout << s1.length() << endl; cout << s1.empty() << endl;
    // 一样第二个参数是count,不是截至位置
    string s2 = s1.substr(1, /*4*/string::npos); // string::npos == 4294967295
    cout << s2 << endl; //find
    /*
    size_type find(
    value_type _Ch,
    size_type _Off = 0
    ) const;
    */
    // 查找某个字符在string中第一次出现的位置(下标),没找到返回 4294967295 最大值
    cout << s1.find('C') << endl; // 2
    //size_type -> size_t ->unsigned int
    /*
    size_type find(
    const value_type* _Ptr,
    size_type _Off = 0
    ) const;
    */
    // 在string中查找字符串,找到返回第一次出现位置的下标,没找到返回 string::npos, 4294967295 最大值
    cout << s1.find("CD") << endl; // 2
    /*
    size_type find(
    const basic_string<CharType, Traits, Allocator>& _Str,
    size_type _Off = 0
    ) const;
    */
    // 在string中查找string
    cout << s1.find(s2) << endl; //rfind,反向查找,返回第一次查找到的下标
    cout << s1.rfind('C') << endl; // 5 //replace
    /*
    basic_string<CharType, Traits, Allocator>& replace(
    size_type _Pos1,
    size_type _Num1,
    const value_type* _Ptr
    );
    */
    // 第三个参数也能是string,这里不写了,只介绍这一个好了
    string s3 = s1;
    s3.replace(1, 2, "RRR");
    cout << s3 << endl; // ARRRDEC // compare
    cout << s3.compare(s1) << endl; // 1, s3 > s1 // insert
    /*
    basic_string<CharType, Traits, Allocator>& insert(
    size_type _P0,
    const value_type* _Ptr
    );
    */
    s3.insert(2, "aaaaaaaaaaa");
    cout << s3 << endl; // ARaaaaaaaaaaaRRDEC // append
    /*
    basic_string<CharType, Traits, Allocator>& append(
    const value_type* _Ptr
    );
    */
    s3.append("OOOOOOOOOOOOOOOOO");
    cout << s3 << endl; // ARaaaaaaaaaaaRRDECOOOOOOOOOOOOOOOOO // swap
    /*
    void swap(
    basic_string<CharType, Traits, Allocator>& _Str
    );
    */
    s3.swap(s2);
    cout << s3 << endl;
    cout << s2 << endl; return 0;
    }

  4. string综合应用
      在字符集中查找存在的首尾字符,并截取。
    #include <iostream>
    #include <string>
    using namespace std; int main()
    {
    string strinfo = " //*---------Hello World!--------------*//";
    string strset = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
    /*
    size_type find_first_of(
    const basic_string<CharType, Traits, Allocator>& _Str,
    size_type _Off = 0
    ) const;
    */
    string::size_type first = strinfo.find_first_of(strset);
    if (first == string::npos)
    cout << "not found." << endl;
    string::size_type end = strinfo.find_last_of(strset);
    if (end == string::npos)
    cout << "not found." << endl;
    //cout << "string::npos" << string::npos << endl; // string::npos == 4294967295
    cout << strinfo.substr(first, end - first + 1) << endl; return 0;
    }

  5. string简单去除字符串左右空格
    // string 简单实现去除字符串左右空格
    #include <iostream>
    #include <string>
    using namespace std; class StringUtils {
    public:
    static void LTrim(string &s)
    {
    string drop = " \t";
    s.erase(0, s.find_first_not_of(drop));
    } static void RTrim(string &s)
    {
    string drop = " \t";
    s.erase(s.find_last_not_of(drop)+1);
    } static void Trim(string &s)
    {
    LTrim(s);
    RTrim(s);
    }
    }; int main(void)
    {
    string s1 = " ABCD ";
    StringUtils::Trim(s1);
    cout << s1 << endl; // "ABCD"
    cout << s1.size() << endl; // 4 return 0;
    }

http://www.cnblogs.com/ifpelset/articles/4523925.html

std::string 简单入门的更多相关文章

  1. 标准C++类std::string的内存共享和Copy-On-Write...

    标准C++类std::string的 内存共享和Copy-On-Write技术 陈皓 1. 概念 Scott Meyers在<More Effective C++>中举了个例子,不知你是否 ...

  2. 【转】标准C++类std::string的内存共享和Copy-On-Write技术

    1.             概念 Scott Meyers在<More Effective C++>中举了个例子,不知你是否还记得?在你还在上学的时候,你的父母要你不要看电视,而去复习功 ...

  3. 标准C++类std::string的内存共享和Copy-On-Write技术

    标准C++类std::string的  内存共享和Copy-On-Write技术 陈皓 1. 概念 Scott Meyers在<More Effective C++>中举了个例子,不知你是 ...

  4. [原创]MYSQL的简单入门

    MYSQL简单入门: 查询库名称:show databases; information_schema mysql test 2:创建库 create database 库名 DEFAULT CHAR ...

  5. could not deduce template argument for 'const std::_Tree<_Traits> &' from 'const std::string'

    VS2008, 写一个简单的demo的时候出现了这个: 1>------ Build started: Project: GetExportTable, Configuration: Relea ...

  6. Okio 1.9简单入门

    Okio 1.9简单入门 Okio库是由square公司开发的,补充了java.io和java.nio的不足,更加方便,快速的访问.存储和处理你的数据.而OkHttp的底层也使用该库作为支持. 该库极 ...

  7. 【java开发系列】—— spring简单入门示例

    1 JDK安装 2 Struts2简单入门示例 前言 作为入门级的记录帖,没有过多的技术含量,简单的搭建配置框架而已.这次讲到spring,这个应该是SSH中的重量级框架,它主要包含两个内容:控制反转 ...

  8. C++: std::string 与 Unicode 结合

    一旦知道 TCHAR 和_T 是如何工作的,那么这个问题很简单.基本思想是 TCHAR 要么是char,要么是 wchar_t,这取决于_UNICODE 的值: // abridged from tc ...

  9. C++: std::string 与 Unicode 如何结合?

    关键字:std::string Unicode 转自:http://www.vckbase.com/document/viewdoc/?id=1293 一旦知道 TCHAR 和_T 是如何工作的,那么 ...

随机推荐

  1. PatentTips - Emulating a host architecture in guest firmware

    BACKGROUND The inventive subject matter relates generally to guest firmware systems, and more partic ...

  2. IOS8刷机之后

    用的4s,明显感觉卡- =BUG也非常多,点击设置都闪退..有些应用打不开. 不建议非开发人员尝试. 眼下发现的bug有:同一时候关闭多个应用会造成应用无法关闭. 常常重新启动.耗电没留意.

  3. FFTW库+VS2012配置

    配置环境:Windows7+VS2012 下载资源包,解压后例如以下图: 要嵌入VS2012中,须要相应的lib文件,于是接下来使用VS2012来生成相应的lib文件 在VS2012/Common7/ ...

  4. pstack.sh 改进版

    pstack.sh 改进版本 #!/bin/bash if (( $# < 1 )) ; then echo "usage: `basename $0` pid" 1> ...

  5. windows go 安装

    go的安装很简单,下载go的msi文件 这里提供go1.9的msi下载链接 https://www.lanzous.com/i2gb54d 直接全部next就行,默认安装在了c盘的go 然后配置环境变 ...

  6. angular自定义指令相关知识及代码

    原文地址 https://www.jianshu.com/p/0c015862156d 大纲 1.自定义指令之——属性指令 2.自定义属性指令的运行原理 3.自定义属性指令代码实践 4.自定义结构指令 ...

  7. 【心情】"支NMLGB配树”

    大视野oj坏了 那就做杭电呗 看看大触都做杭电里的哪些题 看到杭电的分类了 Tarjan算法诶,我好像会嘛,就是你了 诶,怎么不是求强连通分量? 哦,原来是Tarjan算法的另外一个应用叫做支配树 我 ...

  8. 【23.39%】【codeforces 558C】Amr and Chemistry

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  9. js课程 1-5 js如何测试变量的数据类型

    js课程 1-5 js如何测试变量的数据类型 一.总结 一句话总结:用typeof()方法. 1.js如何判断变量的数据类型? 用typeof()方法. 13 v=10; 14 15 if(typeo ...

  10. 某整形数组中除了两个单身整数外, 其余的整数都是成对出现的, 利用C/C++代码求出这两个单身整数。 要求: 时间复杂度o(n), 空间复杂度o(1)------某公司招聘试题

    先看看这个题目:某整形数组中除了两个单身整数外, 其余的整数都是成对出现的, 利用C代码求出这两个单身整数. 要求: 时间复杂度o(n), 空间复杂度o(1). 我们先用最傻瓜的方式来做吧: #inc ...