1.赋值

char赋值:

  char ch1[] = "give me";

  char ch2[] = "a cup";

  strcpy(ch1,ch2);

  cout<<"ch1="<<ch1<<endl;

输出结果:ch1=a cup

string赋值:

  string str1 = "give me";

  string str2 = "a cup";

  ①str1 = str2;

     cout<<"str1="<<str1<<endl;

  ②str1.assign(str2,0,5);       // 参数2为起始位置,参数3为字符数

     cout<<"str1="<<str1<<endl;

输出结果:str1=a cup

     str1=a cup

2.合并(全部)

char合并(全部):

  char ch1[15] = "give me "; // 注意长度,合并后为13

  char ch2[] = "a cup";

  strcat(ch1,ch2);

  cout<<"ch1="<<ch1<<endl;

输出结果:ch1=give me a cup

string合并(全部)

  string str1 = "give me ";

  string str2 = "a cup";

  str1 = str1 + str2;

  cout<<"str1="<<str1<<endl;

输出结果:str1=give me a cup

3.合并(部分)

char合并(部分):

  char ch1[10] = "ab";  // 注意合并后的长度

  char ch2[] = "abc";

  strncat(ch1,ch2,3);    // 参数3为从起始位置起的字符数

  cout<<"ch1="<<ch1<<endl;

输出结果:ch1=ababc

string合并(部分):

  string str1 = "ab";

  string str2 = "cdefg";

  str1.append(str2,2,3); // 参数2为数组下标,参数3为参数2后字符数。即将str2从下标为2位置起3个字符合并到str1

  cout<<"str1="<<str1<<endl;

输出结果:str1=abefg  

4.测长

char测长:

  char ch1[] = "give me";

  int m = strlen(ch1);  //不包括‘\0’

  cout<<"m="<<m<<endl;

输出结果:m=7

string测长:

  string str1 = "give me";

  ①int m = strlen(str1.c_str());

     cout<<"m="<<m<<endl;

  ②int n = str1.size();

     cout<<"n="<<n<<endl;

  ③int k = str1.length();

     cout<<"k="<<k<<endl;

输出结果:m=7

       n=7

           k=7

5.替换

char替换:

  char ch1[10] = "ab";

  char ch2[] = "cdefg";

  strncpy(ch1,ch2,3);       // 拷贝ch2起始位置后3个字符赋给ch1

  cout<<"ch1="<<ch1<<endl;

输出结果:ch1=cde

string替换:

  string str1 = "ab";

  string str2 = "cdefgh";

  str1.replace(0,1,str2,4,2);  // 将str2从下标4开始2个字符替换掉str1中从起始位置开始1个字符

                // replace函数可重载,有多种形式,也支持Char型字符替换

  cout<<"str1="<<str1<<endl;

输出结果:str1=ghb

6.拷贝

char拷贝:

  char ch1[10] = "abc";

  char ch2[] = "de";

  memmove(ch1,ch2,2); //将ch2从起始位置起两个字符赋给ch1

  cout<<"ch1="<<ch1<<endl;

输出结果:ch1=dec

string拷贝:

  string str1 = "abc";

  char ch2[10] = "defg";

  str1.copy(ch2,10,1);    // copy函数的第一个参数只能为char类型

               // 将str1从下标1位置开始的10个字符赋给ch2

  cout<<"ch2="<<ch2<<endl;

输出结果:ch2=bcfg

7.插入

  string str1 = "1278";

  string str2 = "3456";

  str1.insert(2,str2,0,4);   // 在str1下标为2的位置插入str2起始位置后4个字符

  cout<<"str1="<<str1<<endl;

输出结果:str1=12345678

8.删除

  string str("give me");

  str.erase(2,2); // 删除从下标为2位置起两个字符

  cout<<"str="<<str<<endl;

  str.erase(2);  // 删除下标为2位置后全部字符

  cout<<"str="<<str<<endl;

  str.erase();    // 删除所有字符

  cout<<"str="<<str<<endl;

输出结果:str=gi me

     str=gi

     str=

9.查找

  string str("Hello worldw");

  int m = str.find('w',0);   // 从str起始位置开始查找w字符

  cout<<"m="<<m<<endl;

  int n = str.find_first_not_of('w',0);  // 查找str起始位置开始不是w的字符

  cout<<"n="<<n<<endl;

  int k = str.find_first_of('w',0);  // 从str起始位置开始查找第一个w字符

  cout<<"k="<<k<<endl;

  int l = str.find_last_of('w');   // 查找最后一个w的位置

  cout<<"l="<<l<<endl;

  int p = str.find_last_not_of('w');  // 查找最后一个不是w的字符的位置

  cout<<"p="<<p<<endl;

  int q = str.rfind('w'); // 反向查找

  cout<<"q="<<q<<endl;

输出结果:m=6

     n=0

     k=6

     l=11

     p=10

     q=11

10.比较

  string str1 = "155";

  string str2 = "52";

  char c[] = "34";

  int i = str1.compare(str2);

  cout<<"i="<<i<<endl;  // 输出i=-1

  int j = str2.compare(c); // string字符串可以与char字符比较

  cout<<"j="<<j<<endl; // 输出j=1

  int l = str1.compare(0,2,str2); // 比较前两个字符

  cout<<"l="<<l<<endl; // 输出l=-1;

  int k = str1.compare(1,1,str2,0,1); // str1下标为1位置字符与str2下标为0位置字符比较

  cout<<"k="<<k<<endl; // 输出k=0

  int m = str1.compare(1,1,c,0,1);

  cout<<"m="<<m<<endl;// 输出m=1

  int n = str1.compare(1,1,c,1);

  cout<<"n="<<n<<endl; // 输出n=1

11.判空

  string str = "";

  if(str.empty())

12.转换(string转字符数组)

  string str1 = "Hello World";

  const char* ch1;

  ch1 = str1.c_str();

13.交换

char交换:

  char ch1[15] = "ofru";

  char ch2[15] = "";

  swab(ch1,ch2,strlen(ch1));  // 将ch1奇偶对调后传入ch2

  cout<<"ch2="<<ch2<<endl;

输出结果:ch2=four

string交换:

  string str1 = "four";

  string str2 = "";

  str1.swap(str2);

  cout<<"str2="<<str2<<endl;

输出结果:str2=four

306573704 Char型和string型字符串比较整理(转)的更多相关文章

  1. Char型和string型字符串比较整理

    1.赋值 char赋值: char ch1[] = "give me"; char ch2[] = "a cup"; strcpy(ch1,ch2); cout ...

  2. 关于 float 型和 double 型的区别,以及 char 型和 String 型的不同

    一.1.float是单精度浮点数,内存分配4个字节,占32位,有效小数位6-7位 double是双精度浮点数,内存分配8个字节,占64位,有效小数位15位 2.java中默认声明的小数是double类 ...

  3. char型字符串(数组)与string型字符串 指针与引用

    一.常指针: int *const p;    //指针不可改变,但是指针指向的数据可以改变. 指向常量的指针: const int *p;    //指针可以改变,但是指针指向的数据不可以改变. 指 ...

  4. 用scanf、printf输入输出string型字符串

    c语言里是没有string型的,string在c++里面.有的时候在c++里要用scanf.printf输入输出string型字符串,这是可以实现的,不过要做一点处理. 具体操作看代码: #inclu ...

  5. C字符串和C++中string的区别 &&&&C++中int型与string型互相转换

    在C++中则把字符串封装成了一种数据类型string,可以直接声明变量并进行赋值等字符串操作.以下是C字符串和C++中string的区别:   C字符串 string对象(C++) 所需的头文件名称 ...

  6. C++ 中 int,char*,string,CString之间相互转换-整理

    <多字符集下> #include <string> //使用C++标准库的string类时, 定义时 std::string str; using namespace std; ...

  7. 18:字符串-char型字符串

    1 什么是字符串? 字符串是以空字符(\)结尾的字符数组.空字符的assii码为:0, 空格的ascii码为322 \0的作用'\0'是一个空字符标志,它的ASSII码为0,C++有好多处理字符串的函 ...

  8. char*、string、CString各种字符串之间转换

    参考博客: http://blog.csdn.net/luoweifu/article/details/20242307 http://blog.csdn.net/luoweifu/article/d ...

  9. 关于如何将_variant_t型转化为int型和string类型

    1)将_variant_t型转化为int型 关于将_variant_t型转化为int型,网上有好多好多参考,但好多都很复杂并且还不对,其实整个转化过程就只一行代码可以搞定: _variant_t a; ...

随机推荐

  1. easyui tree在struts1中的使用

    前段时间写过类似的功能,开发环境是struts2,jdk1.6,tomcat 而这次是修改N年前的项目 项目的开发环境为struts1,jdk1.4,weblogic8,比较过时所以就增加了使用eas ...

  2. Sql sp_executesql 参数问题

    DECLARE @name NVARCHAR(30), @sql NVARCHAR(300)set @sql= N'SELECT TOP 1 @n=EmpName from dbo.Emp' exec ...

  3. JS基础DOM篇之一:何为DOM?

    近日在园子看了一篇文章,一位前端负责人问应聘者何为DOM事件流的三个阶段,我当时一看也是懵圈,于是强迫症复发,遂想要搞清楚它.谁知在查资料的过程中发现有好多关于DOM的概念也是模糊不清,便决定继续延伸 ...

  4. 最牛X的编码套路

    最近,我大量阅读了Steve Yegge的文章.其中有一篇叫"Practicing Programming"(练习编程),写成于2005年,读后令我惊讶不已: 与你所相信的恰恰相反 ...

  5. IOS开发常用技术网站

    IOS常用网站:    1.http://www.cocoachina.com    2.http://oschina.net    3.http://code4app.com

  6. AdventureWorks Databases 2008 下载地址

    AdventureWorks Databases 2008 下载地址: RECOMMENDED DOWNLOAD  AdventureWorks2012_Database.zip example, 3 ...

  7. 一个方便的shell命令,查看软件安装目录

    查看软件安装路径:whereis phpfind / -name nginx.configfind 查找 / 从根目录 -name 文件查找

  8. BZOJ 2241: [SDOI2011]打地鼠 暴力

    2241: [SDOI2011]打地鼠 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pro ...

  9. 基于华为Java编程规范的Eclipse checkStyle.xml

    发现项目组成员代码规范存在较大的问题,于是就在华为编程规范的基础上制定了这份checkStyle.xml文档,至于Eclipse怎么安装checkStyle插件以及该插件怎么使用请自行Google之. ...

  10. C++和python使用struct传输二进制数据结构来实现

    网络编程问题往往涉及二进制数据的传输.在C++经常使用的传输是文本字符串和分组结构. 假设该数据可以预先送入连续的内存区域,然后让send函数来获得的第一个地址,这一块连续的内存区就能完成传输数据.文 ...