当前位置: 首页 > news >正文

做的好的阅读类的网站有哪些适合奖励自己的网站免费

做的好的阅读类的网站有哪些,适合奖励自己的网站免费,自己制作app需要什么,电子工程网网站我们知道在C语言里,字符串是以\0结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数, 但是这些库函数与字符串是分离开的,而且底层空间需要用户自己管理,可 能还会越界访问。 但是在C…

我们知道在C语言里,字符串是以'\0'结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数, 但是这些库函数与字符串是分离开的,而且底层空间需要用户自己管理,可 能还会越界访问。

但是在C++里,却实现了string类,这个string类大大方便了字符串的定义,增添,删除等操作

定义/赋值/增添/合并

int main()
{string s1("hello world");string s2="hello linux";  string s3=s2;string s4;s4=s2;string s5=s1+s2;string ret2 = s1 + "我来了";return 0;
}

迭代器

顺序

假如我们想对字符串进行遍历,那么就需要用迭代器

int main()
{    string s1("hello world");string::iterator it = s1.begin();//begin()函数返回一个迭代器,指向字符串的第一个元素.while (it != s1.end());//end()函数返回一个迭代器,指向字符串的末尾{cout << *it << " ";//打印++it;*it = 'a';//也可以进行修改}cout << endl;return 0;
}

迭代器就类似于一个指针,指向了第一个字母的地址,' * '就是进行解引用

逆序

若是想对字符串进行倒序的读取

string s1("hello world");
auto rit = s1.rbegin();//可以用auto 自动判断类型
while (rit != s1.rend())
{cout << *rit << " ";++rit;
}
cout << endl;

提取字符

//选定字符串,开始的位置,要的字符数
// source_str  pos  num
string s1("hello world");
string s3(s1, 0, 5);string s5("hello linuxaaaaaaaaaaaaaaaaaaa");
string s6(s5, 6);
//npos(最后一个取的数字不填入)-直接取到最后一个 (npos=-1)string s9(++s8.begin(), --s8.end());//也可以用区间
cout << s9 << endl;

读取长度

string s1("hello world");
//大小
cout << s1.size() << endl;
cout << s1.length() << endl;//容量
cout << s1.capacity() << endl;//clear清理数据
s1.clear();//最大容量
cout << s1.max_size() << endl;

ps:容量capacity不会缩小,只会增大

保存空间/预定空间

string s;
s.reserve(100);//保存100个数据的空间,确定知道大概要多少空间,提前开好,减少扩容,提高效率

改变大小

string s("hello world");
cout << s.size() << endl;
cout << s.capacity() << endl;
cout << s << endl;
//s.resize(13);//默认用'\0'进行改变容量
s.resize(13, 'x');//也可以修改为用'x'进行容量的改变

获取指定位置的字符

s.at(0)++;
s[0]++;
//二者一样,但是at访问失败会返回一个抛异常cout << s2 << endl;

尾插

string ss("world");
string s;
s.push_back('#');//#后加上s的内容
s.append("hello");//在其后边加上这个 
cout << s << endl;
s.append(ss);//在s后边加上ss的内容
cout << s << endl;
s += '#';
s += "hello";
s += ss;
cout << s << endl;

粘贴/拷贝

string str;
string base = "dasdasdasdasdasdasdasd";
str.assign(base);//将base的数据拷贝给str,若str已经有数据,那么就会将已有的数据进行覆盖
cout << str << endl;str.assign(base, 5, 10);//resource pos num
cout << str << endl;

查找

string s1("test.cpp");
size_t i = s1.find(".");//找到.的位置,返回下标string s2 = s1.substr(i);//begin..num-num决定了保留的个数,若不输入则默认到结尾
cout << s2 << endl;//如果有多个重复的字符呢?-rfind,返回最后一个出现要找在字符的位置
string s3("test.cpp.tar.zip");
size_t m = s3.rfind('.');
string s4 = s3.substr(m);
cout << s4 << endl;string s5("");

特殊查找

string str("Please, replace the vowels in this sentence by mistakes.");
size_t found = str.find_first_of("aeiou");//找到其中之一的字符即可
//size_t found = str.find("a");
while (found != string::npos)
{str[found] = '*';found = str.find_first_of("aeiou", found + 1);//found = str.find("a", found + 1);
}
cout << str << '\n';

find和find_first_of 区别就是,find是完美匹配要查找的字符串,find_first_of找到其中一个符合的字符即可

除此之外string类里还有很多函数,例如insert erase replace等,可以查,不需要强制记忆,但是上述是比较经常用的,按需记忆。

http://www.shuangfujiaoyu.com/news/54717.html

相关文章:

  • 市住房建设委官方网站腾讯新闻最新消息
  • 上海有名的做网站的公司免费发布信息不收费的网站
  • 可以用服务器做网站运营推广seo招聘
  • 杭州做网站公司友情链接网自动收录
  • 网站建设在哪里发布搜索引擎营销的内容有哪些
  • java可以做网站点击器免费版
  • 广州中小学智慧阅读门户网站app制作费用一览表
  • 时尚字体设计网站网站营销网
  • 建筑招聘网站有哪些店铺推广方式有哪些
  • 虚拟主机网站模板举出最新的网络营销的案例
  • 公司网站优化软件长春seo优化
  • 平面设计线上培训机构推荐南宁百度seo建议
  • 做网站UI说不会写文案班级优化大师的利和弊
  • 深圳国贸网站建设广告加盟
  • 网站建设公司盈利热搜排行榜今日排名
  • 西安汇友网站建设站长工具忘忧草社区
  • 网站被黑怎么恢复百度seo是啥意思
  • 做目录的网站实时排名软件
  • 怎样做网站关键词知乎关键词搜索排名
  • 用css代码做新闻网站怎样自己做网站
  • 网站开发 调试网站建设模板
  • 城关区建设局网站精品成品网站1688
  • 网站备案管理办法品牌推广案例
  • 如何建立asp网站app推广拉新工作可靠吗
  • 网站制作和网页制作区别北京seo实战培训班
  • 做投标的在什么网站找信息今日的新闻头条10条
  • 网站域名怎样注销淘宝流量平台
  • 刷单网站建设产品软文代写
  • 给女朋友做的网站营销软文500字
  • 云南网站制作价格百度云搜索资源入口