C++学习笔记(一)

来源:互联网 发布:幼儿园大班淘宝怎么做 编辑:程序博客网 时间:2024/05/04 06:30

从今天开始将学习C++的笔记记录在这里,也分享给大家。

字符串的操作:

#-----------------------------------------------------------------分割线----------------------------------------------------------------------------#

先看C语言,在C语言中,可以使用<string.h>进行字符串的操作,在这里整理一下字符串常用C语言操作函数

strcpy(char *str1,char *str2);//将str2的内容覆盖到str1中。strncpy(char *str1,char *str2,int x);//将str2的内容前x个字符覆盖到str1中。strcat(char *str1,char *str2);//将str2的内容连接到str1后面,注意str1要足够大。strncat(char *str1,char *str2,int x);//将str2的内容中前x个字符连接到str1后面,注意str1要足够大。strset(char *str1,char 'r');//用'r'完全替换str1函数。strnset(char *str1,char 'r',int x);//用'r'替换str1中前x个字符。int p=strchr(char *str1,char 'r');//查找str1中'r'第一次的位置,返回到p中。int p=strrchr(char *str1,char 'r');//查找str1中'r'最后一次的位置,返回到p中。int p=strcspn(char *str1,char *str2);//查找str1中str2第一次的位置,返回到p中。int p=strcmp(char *str1,char *str2);//比较str1和str2的大小,根据ascii码,大于则返回>0的数字,相等返回0。int p=stricmp(char *str1,char *str2);//比较str1和str2不计大小写的比较,根据ascii码,大于返回>0数字,小于返回<0数字,相等返回0。int p=strncmp(char *str1,char *str2);//str1和str2中前x个字符比较,根据ascii码,大于返回>0数字,小于返回<0数字,相等返回0。int p=strnicmp(char *str1,char *str2,int x);//str1和str2中前x个字符不计大小写的大小比较,根据ascii码,大于返回>0数字,小于返回<0数字,相等返回0。


常用的是以上这些,其实记忆也很简单,主要几个函数记住就好,其他的都是加个n或者i。

#-----------------------------------------------------------------分割线----------------------------------------------------------------------------#

再看C++语言,在C++中,是兼容C语言的,所以C++可以引入<cstring>,就是以前的<string.h>,优点就是处理字符串速度快,缺点是功能不够完善,所以C++中出现了<string>这个类。

定义:

string str1;

string str1 = "i am a student";

赋值:

string str1;

string str2 = "i am a student";

str1=str2;

合并:

str1 = str2 + str3;

常用操作:

//字符串属性int p=str1.length()//字符串长度返回给pint p=str1.size();//字符串大小返回给pbool p=str1.empty()//字符串是否为空//比较和子串int p=str1.compare(str2)//比较str1和str2大小string str2=str1.substr(int p,int n)//取出str1中从p开始的n个字符的字符串给str2//查找int p=str1.find(char c,int n)//从n开始查找字符c第一次出现位置。int p=str1.find(string str2,int n)//从n开始查找字符串str2第一次出现位置。int p=str1.rfind(char c,int n)//从n开始从后向前查找字符c在当前串中的位置int p=str1.rfind(string str2,int n)//从n开始从后向前查找字符串str2在当前串中的位置//替换与插入string str3=str1.replace(int p,int n,string str2);//删除从p开始的n个字符,然后在p处插入串str2string str3=str1.insert(int p,string str2);//删除从p开始的n个字符,然后在p处插入串str2//删除string str2=str1.erase(int p, int n);//删除p开始的n个字符,返回修改后的字符串


#-----------------------------------------------------------------分割线----------------------------------------------------------------------------#

主要就是以上这些,在这里做一个记录。





0 0
原创粉丝点击