内存释放和越界

  越界:(1)、复制越界,(2)、取值越界

构造函数

  (1)、默认 空(无参)

  (2)、拷贝(const string &)

  (3)、带参数: const char *  // ZC: 经测试 和 查看源码,该构造函数也是将指针指向的内容复制一份,而非直接使用参数指针的值。

        int n, char c

字符操作:

  [?]  ==> const char &    (ZC: 获取)

  at(?) ==> const char &    (ZC: 获取)

  [?]  ==> char        (ZC: 设置)

  at(?) ==> char        (ZC: 设置)

[?]越界  ==> 内存错误 ==> 崩溃

at(?)越界 ==> out_of_range异常

出:

  const char *  string::c_str() const;

  ZC: const函数: 不能改变类中非静态成员的值

进:

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

  返回 实际拷贝的字符个数

  s : 为何不使用 "const char* s"?

  n : s中需要拷贝的字符的个数

  pos : s中 起始字符的索引值idx

长度:(不包括结尾的'\0')

  int string::length() const;

  bool string::empty() const;

赋值:

  string& = const string &

  string& assign(const string &)  // 这个和下面的有重复?

  string& assign(const char *s, int n);  // s中的前n个字符

  string& assign(const string &)

  string& assign(const string & s, int start, int n);

    start : s字符中的起始索引

    n : s中的n个字符

连接:

  string& += const string &      尾部

  string& += const char *      尾部

  string& append(const char *);    尾部

  string& append(const char *s, int n);    s中的前n个字符,添加到尾部

  string& append(const string &);    尾部

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

    pos : s中字符的开始索引

    n : s中需要拷贝的字符个数

  string& append(int n, char c);    n个字符c,添加到尾部

比较:

  int string::compare(const string *s) const;

  int string::compare(const char *s) const;

    >  返回1

    <  返回-1

    == 返回0

  ASCII码表,越前越小

子串:

  string string::substr(int pos=0, int n=npos) const;

    pos : 开始索引

    n : n个字符(默认值npos是指string中的全部字符吗?)

查找:

  int string::find(char c, int pos=0) const;  // 从pos开始找字符c的位置

  int string::find(const char *s, int pos=0) const;  // 从pos开始找字符串s的位置

  int string::find(const string &s, int pos=0) const;  // 从pos开始找字符串s的位置

    找不到,返回-1

    找到第一个符合条件的,就返回吗?

  

  int string::rfind(char c, int pos=0) const;  // 从pos开始找字符c的位置

  int string::rfind(const char *s, int pos=0) const;  // 从pos开始找字符串s的位置

  int string::rfind(const string &s, int pos=0) const;  // 从pos开始找字符串s的位置

    找不到,返回-1

    找到第一个符合条件的,就返回吗?

    返回的是 正向的索引值?还是逆向的索引值?

插入:

  string& string::insert(int pos, const char *s);  // 在pos位置插入字符串s

  string& string::insert(int pos, const string &s);  // 在pos位置插入字符串s

  string& string::insert(int pos, int n, char c);  // 在pos位置插入 n个字符c

删除:

  string& string::erase(int pos=0, int n=npos); // 删除pos开始的n个字符,返回删除后的字符串

替换:

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

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

  这两个函数是分两个步骤执行的:

    (1)、删除 pos开始的 n个字符

    (2)、pos处 插入 字符串s

交换:

  void string::swap(string & s2);

string_01的更多相关文章

随机推荐

  1. js 俄罗斯方块源码,简单易懂

    1.自己引入jquery <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  2. AWS邮件通知服务:实时监控邮件状态

    以下为译文: 订阅“AWS中文技术社区”微信公众号,实时掌握AWS技术及产品消息! AWS中文技术社区为广大开发者提供了一个Amazon Web Service技术交流平台,推送AWS最新资讯.技术视 ...

  3. linux 统计wc

    说明:该命令统计给定文件中的字节数.字数.行数.如果没有给出文件名,则从标准输入读取.wc同时也给出所有指定文件的总统计数.字是由空格字符区分开的最大字符串. 该命令各选项含义如下: - c 统计字节 ...

  4. linux安装composer及安装yii2

    wget https://getcomposer.org/download/1.3.2/composer.phar mv composer.phar /usr/local/bin/composer c ...

  5. 710 Random Pick with Blacklist

    1. 问题 给定一个黑名单,包含[0, N)的一些数,从[0, N)之间的非黑名单数中随机采样一个值. 2. 思路 字典映射 (1)计算黑名单数的长度,记作B,因为已经排除掉了B个元素,所以最后是从N ...

  6. linux常用命令:chgrp 命令

    在 lunix系统里,文件或目录的权限的掌控以拥有者及所诉群组来管理.可以使用chgrp指令变更文件与目录所属群组,这种方式采用群组名称或群组识别 码都可以.chgrp命令就是change group ...

  7. Bootstrap+AngularJS对话框实例

    <script type="text/javascript" src="/assets/JS/plugins/jquery.min.js">< ...

  8. Django框架----ORM数据库操作

    一.ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用 ...

  9. mysql查询操作1

    ##1.在已有的表中插入一行记录 insert into tb_name values("",""...); ##2.查询语句的框架和用法 select 字段名 ...

  10. jdbc连接池c3p0/dbcp强制连接超过设置时间后失效

    通常来说,各种技术实现的优化参数或者选项或者歪门邪道之所以能被想出来,通常是因为开发者或者实现的贡献者曾经遇到过导致此结果的问题,所以才出了对应的策略选项. 在有些情况下,比如存在客户端或者服务端连接 ...