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

  

以上,整理自《范磊C++视频》笔记

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

  1. 306573704 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. CAS SSO

    1.      CAS 简介 1.1.  What is CAS ? CAS ( Central Authentication Service ) 是 Yale 大学发起的一个企业级的.开源的项目,旨 ...

  2. Hadoop: HDFS 格式化时,出现 “ERROR namenode.NameNode: java.io.IOException: Cannot create directory /usr/hadoop/tmp/dfs/name/current”

    原因是 没有设置 /usr/hadoop/tmp 的权限没有设置, 将之改为: chown –R hadoop:hadoop /usr/hadoop/tmp 查看:

  3. 【转】SSIS 2012 – Package Configurations Menu Option Missing

    原文:http://dataqueen.unlimitedviz.com/2012/01/ssis-2012-package-configurations-menu-option-missing/ I ...

  4. C++中把string转成char

    c_str函数的返回值是const char*的,不能直接赋值给char*, c++语言提供了两种字符串实现,其中较原始的一种只是字符串的c语言实现. 与C语言的其他部分一样,它在c+的所有实现中可用 ...

  5. 改错+GetMemory问题

    试题1: void test1() { ]; "; strcpy( string, str1 ); } 试题2: void test2() { charstring[],str1[]; in ...

  6. PHP扩展开发之简单类开发

    接下来我们要用扩展的形式实现以下类(演示环境:linux.php-5.5.34-src) <?php class Person { private $_name; public function ...

  7. Windows Message Queue--hdu1509

    Windows Message Queue Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Ot ...

  8. Big Number

    问题陈述: 杭州电子科技大学 HANGZHOU DIANZI UNIVERSITY Online Judge Problem - 1018 问题解析: 公式一: n! = 10^m => lg( ...

  9. 四巧工作简化法(ECRS)

    在构思项目的工作方法时,可以运用ECRS(四巧工作简化法)技术,即E取消.C合并.R重排.S简化等四种技巧. 1.取消(Eliminate) 对所做的项目,首先应当考虑取消的可能性.如果所做的项目.工 ...

  10. Elf 32

    [CentOS]安装软件:/ld-linux.so.2: ELF interpreter解决   环境: [orangle@localhost Downloads]$ uname -m&&am ...