原文地址:c++常用字符串操作函数作者:Valsun

函数名: stpcpy

功 能: 拷贝一个字符串到另一个

用 法: char *stpcpy(char *destin, char *source);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char string[10];

   char *str1 =
"abcdefghi";

   stpcpy(string, str1);

   printf("%sn", string);

   return 0;

}

函数名: strcat

功 能: 字符串拼接函数

用 法: char *strcat(char *destin, char *source);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char destination[25];

   char *blank = " ", *c = "C++",
*Borland = "Borland";

   strcpy(destination,
Borland);

   strcat(destination,
blank);

   strcat(destination, c);

   printf("%sn",
destination);

   return 0;

}

函数名: strchr

功 能: 在一个串中查找给定字符的第一个匹配之处

用 法: char *strchr(char *str, char c);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

    char
string[15];

    char *ptr, c
= 'r';

   
strcpy(string, "This is a string");

    ptr =
strchr(string, c);

    if
(ptr)

      
printf("The character %c is at position: %dn", c,
ptr-string);

    else

      
printf("The character was not foundn");

    return
0;

}

函数名: strcmp

功 能: 串比较

用 法: int strcmp(char *str1, char *str2);

看Asic码,str1>str2,返回值 >
0;两串相等,返回0

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

    char *buf1 =
"aaa", *buf2 = "bbb", *buf3 = "ccc";

    int
ptr;

    ptr =
strcmp(buf2, buf1);

    if (ptr
> 0)

      
printf("buffer 2 is greater than buffer 1n");

    else

      
printf("buffer 2 is less than buffer 1n");

    ptr =
strcmp(buf2, buf3);

    if (ptr
> 0)

      
printf("buffer 2 is greater than buffer 3n");

    else

      
printf("buffer 2 is less than buffer 3n");

    return
0;

}

函数名: strncmpi

功 能: 将一个串中的一部分与另一个串比较, 不管大小写

用 法: int strncmpi(char *str1, char *str2, unsigned maxlen);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "BBB", *buf2 =
"bbb";

   int ptr;

   ptr = strcmpi(buf2,
buf1);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   if (ptr <
0)

     
printf("buffer 2 is less than buffer 1n");

   if (ptr == 0)

     
printf("buffer 2 equals buffer 1n");

   return 0;

}

函数名: strcpy

功 能: 串拷贝

用 法: char *strcpy(char *str1, char *str2);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

    char
string[10];

    char *str1 =
"abcdefghi";

   
strcpy(string, str1);

   
printf("%sn", string);

    return
0;

}

函数名: strcspn

功 能: 在串中查找第一个给定字符集内容的段

用 法: int strcspn(char *str1, char *str2);

程序例:

#include <stdio.h>

#include <string.h>

#include <alloc.h>

int main(void)

{

    char
*string1 = "1234567890";

    char
*string2 = "747DC8";

    int
length;

    length =
strcspn(string1, string2);

   
printf("Character where strings intersect is at position %dn",
length);

    return
0;

}

函数名: strdup

功 能: 将串拷贝到新建的位置处

用 法: char *strdup(char *str);

程序例:

#include <stdio.h>

#include <string.h>

#include <alloc.h>

int main(void)

{

    char
*dup_str, *string = "abcde";

    dup_str =
strdup(string);

   
printf("%sn", dup_str);

   
free(dup_str);

    return
0;

}

函数名: stricmp

功 能: 以大小写不敏感方式比较两个串

用 法: int stricmp(char *str1, char *str2);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "BBB", *buf2 =
"bbb";

   int ptr;

   ptr = stricmp(buf2,
buf1);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   if (ptr <
0)

     
printf("buffer 2 is less than buffer 1n");

   if (ptr == 0)

     
printf("buffer 2 equals buffer 1n");

   return 0;

}

函数名: strerror

功 能: 返回指向错误信息字符串的指针

用 法: char *strerror(int errnum);

程序例:

#include <stdio.h>

#include <errno.h>

int main(void)

{

   char *buffer;

   buffer =
strerror(errno);

   printf("Error: %sn",
buffer);

   return 0;

}

函数名: strcmpi

功 能: 将一个串与另一个比较, 不管大小写

用 法: int strcmpi(char *str1, char *str2);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "BBB", *buf2 =
"bbb";

   int ptr;

   ptr = strcmpi(buf2,
buf1);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   if (ptr <
0)

     
printf("buffer 2 is less than buffer 1n");

   if (ptr == 0)

     
printf("buffer 2 equals buffer 1n");

   return 0;

}

函数名: strncmp

功 能: 串比较

用 法: int strncmp(char *str1, char *str2, int maxlen);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "aaabbb", *buf2 =
"bbbccc", *buf3 = "ccc";

   int ptr;

   ptr =
strncmp(buf2,buf1,3);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   else

     
printf("buffer 2 is less than buffer 1n");

   ptr =
strncmp(buf2,buf3,3);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 3n");

   else

     
printf("buffer 2 is less than buffer 3n");

   return(0);

}

函数名: strncmpi

功 能: 把串中的一部分与另一串中的一部分比较, 不管大小写

用 法: int strncmpi(char *str1, char *str2);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "BBBccc", *buf2 =
"bbbccc";

   int ptr;

   ptr =
strncmpi(buf2,buf1,3);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   if (ptr <
0)

     
printf("buffer 2 is less than buffer 1n");

   if (ptr == 0)

     
printf("buffer 2 equals buffer 1n");

   return 0;

}

函数名: strncpy

功 能: 串拷贝

用 法: char *strncpy(char *destin, char *source, int maxlen);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char string[10];

   char *str1 =
"abcdefghi";

   strncpy(string, str1,
3);

   string[3] = '';

   printf("%sn", string);

   return 0;

}

函数名: strnicmp

功 能: 不注重大小写地比较两个串

用 法: int strnicmp(char *str1, char *str2, unsigned maxlen);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *buf1 = "BBBccc", *buf2 =
"bbbccc";

   int ptr;

   ptr = strnicmp(buf2, buf1,
3);

   if (ptr >
0)

     
printf("buffer 2 is greater than buffer 1n");

   if (ptr <
0)

     
printf("buffer 2 is less than buffer 1n");

   if (ptr == 0)

     
printf("buffer 2 equals buffer 1n");

   return 0;

}

函数名: strnset

功 能: 将一个串中的所有字符都设为指定字符

用 法: char *strnset(char *str, char ch, unsigned n);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char *string =
"abcdefghijklmnopqrstuvwxyz";

   char letter = 'x';

   printf("string before strnset:
%sn", string);

   strnset(string, letter,
13);

   printf("string after strnset:
%sn", string);

   return 0;

}

函数名: strpbrk

功 能: 在串中查找给定字符集中的字符

用 法: char *strpbrk(char *str1, char *str2);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char *string1 =
"abcdefghijklmnopqrstuvwxyz";

   char *string2 = "onm";

   char *ptr;

   ptr = strpbrk(string1,
string2);

   if (ptr)

     
printf("strpbrk found first character: %cn", *ptr);

   else

     
printf("strpbrk didn't find character in setn");

   return 0;

}

函数名: strrchr

功 能: 在串中查找指定字符的最后一个出现

用 法: char *strrchr(char *str, char c);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char string[15];

   char *ptr, c = 'r';

   strcpy(string, "This is a
string");

   ptr = strrchr(string,
c);

   if (ptr)

     
printf("The character %c is at position: %dn", c,
ptr-string);

   else

     
printf("The character was not foundn");

   return 0;

}

函数名: strrev

功 能: 串倒转

用 法: char *strrev(char *str);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char *forward =
"string";

   printf("Before strrev():
%sn", forward);

   strrev(forward);

   printf("After strrev(): %sn",
forward);

   return 0;

}

函数名: strset

功 能: 将一个串中的所有字符都设为指定字符

用 法: char *strset(char *str, char c);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char string[10] =
"123456789";

   char symbol = 'c';

   printf("Before strset():
%sn", string);

   strset(string, symbol);

   printf("After strset(): %sn",
string);

   return 0;

}

函数名: strspn

功 能: 在串中查找指定字符集的子集的第一次出现

用 法: int strspn(char *str1, char *str2);

程序例:

#include <stdio.h>

#include <string.h>

#include <alloc.h>

int main(void)

{

   char *string1 =
"1234567890";

   char *string2 =
"123DC8";

   int length;

   length = strspn(string1,
string2);

   printf("Character where
strings differ is at position %dn", length);

   return 0;

}

函数名: strstr

功 能: 在串中查找指定字符串的第一次出现

用 法: char *strstr(char *str1, char *str2);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char *str1 = "Borland
International", *str2 = "nation", *ptr;

   ptr = strstr(str1,
str2);

   printf("The substring is:
%sn", ptr);

   return 0;

}

函数名: strtod

功 能: 将字符串转换为double型值

用 法: double strtod(char *str, char **endptr);

程序例:

#include <stdio.h>

#include <stdlib.h>

int main(void)

{

   char input[80], *endptr;

   double value;

   printf("Enter a floating point
number:");

   gets(input);

   value = strtod(input,
&endptr);

   printf("The string is %s the
number is %lfn", input, value);

   return 0;

}

函数名: strtok

功 能: 查找由在第二个串中指定的分界符分隔开的单词

用 法: char *strtok(char *str1, char *str2);

程序例:

#include <string.h>

#include <stdio.h>

int main(void)

{

   char input[16] =
"abc,d";

   char *p;

  

   p = strtok(input, ",");

   if
(p)   printf("%sn", p);

  

   p = strtok(NULL, ",");

   if
(p)   printf("%sn", p);

   return 0;

}

函数名: strtol

功 能: 将串转换为长整数

用 法: long strtol(char *str, char **endptr, int base);

程序例:

#include <stdlib.h>

#include <stdio.h>

int main(void)

{

   char *string = "87654321",
*endptr;

   long lnumber;

  

   lnumber = strtol(string,
&endptr, 10);

   printf("string = %s long =
%ldn", string, lnumber);

   return 0;

}

函数名: strupr

功 能: 将串中的小写字母转换为大写字母

用 法: char *strupr(char *str);

程序例:

#include <stdio.h>

#include <string.h>

int main(void)

{

   char *string =
"abcdefghijklmnopqrstuvwxyz", *ptr;

  

   ptr = strupr(string);

   printf("%sn", ptr);

   return 0;

}

函数名: swab

功 能: 交换字节

用 法: void swab (char *from, char *to, int nbytes);

程序例:

#include <stdlib.h>

#include <stdio.h>

#include <string.h>

char source[15] = "rFna koBlrna d";

char target[15];

int main(void)

{

   swab(source, target,
strlen(source));

   printf("This is target: %sn",
target);

   return 0;

}

[转载]c++常用字符串操作函数的更多相关文章

  1. C语言的常用字符串操作函数(一)

    一直做的是单片机相关的程序设计,所以程序设计上更偏向底层,对于字符串的操作也仅限于液晶屏幕上的显示等工作,想提高下字符串操作的水平,而不是笨拙的数组替换等方式,翻看帖子发现C语言的字符串操作函数竟然这 ...

  2. mysql常用字符串操作函数大全,以及实例

    今天在论坛中看到一个关于mysql的问题,问题如下 good_id     cat_id12654         665,56912655         601,4722 goods_id是商品i ...

  3. VB常用字符串操作函数

    1. ASC(X),Chr(X):转换字符字符码 [格式]: P=Asc(X) 返回字符串X的第一个字符的字符码 P=Chr(X) 返回字符码等于X的字符 [范例]: (1)P=Chr(65) ‘ 输 ...

  4. PHP常用字符串操作函数实例总结(trim、nl2br、addcslashes、uudecode、md5等)

    /*常用的字符串输出函数 * * echo() 输出字符串 * print() 输出一个或多个字符串 * die() 输出一条信息,并退出当前脚本 * printf() 输出格式化字符串 * spri ...

  5. string常用字符串操作函数

    1.strdup和strndup 说明:strdup() 函数将参数 s 指向的字符串复制到一个字符串指针上去,这个字符串指针事先可以没被初始化.在复制时,strdup() 会给这个指针分配空间,使用 ...

  6. 转载:SQL 字符串操作函数

    http://www.cnblogs.com/jiajiayuan/archive/2011/06/16/2082488.html 以下所有例子均Studnet表为例:  计算字符串长度len()用来 ...

  7. golang——(strings包)常用字符串操作函数

    (1)func HasPrefix(s, prefix string) bool 判断字符串s是否有前缀字符串prefix: (2)func HasSuffix(s, suffix string) b ...

  8. LoadRunner中常用的字符串操作函数

    LoadRunner中常用的字符串操作函数有:                strcpy(destination_string, source_string);               strc ...

  9. JavaScript中常见的字符串操作函数及用法

    JavaScript中常见的字符串操作函数及用法 最近几次参加前端实习生招聘的笔试,发现很多笔试题都会考到字符串的处理,比方说去哪儿网笔试题.淘宝的笔试题等.如果你经常参加笔试或者也是一个过来人,相信 ...

随机推荐

  1. 【转】linux下杀死进程

    经过搜集和整理相关的Linux操作系统杀死进程的材料,在这里给大家推荐本篇文章,希望大家看后会有不少收获. 1. kill 作用:根据进程号杀死进程 用法: kill [信号代码] 进程ID 举例: ...

  2. MVC使用Newtonsoft无需实体类,实现JSON数据返回给前端页面使用

    //引用using Newtonsoft.Json; using Newtonsoft.Json.Linq; public ActionResult JsonSample() { ResponseRe ...

  3. 【bzoj3786】星系探索

    ETT模版题. 真正的Eular-Tour-Tree维护的是树的欧拉序. 由于各种原因,没人知道怎么维护欧拉序,所以我写的是个假的,维护dfs序的. 本质还是用Splay维护序列. 然后因为我常数太差 ...

  4. maven项目的多级目录

    刚刚把一个开源的项目变成maven项目来进行管理,由于是多级的目录(以前配置的都是单级的目录),所以记录一下pom文件是怎么配置的. 一.目录结构 如下,maven的结构图,红字是表示完整的项目

  5. 解决Ubuntu的错误提示

    如果你是一个Ubuntu用户,也许偶尔甚至经常,遇到这样一个错误提示“System Program problem detected”. Ubuntu有一个内建的实用程序叫做Apport, 当一个程序 ...

  6. leetcode 之Set Matrix Zeroes(10)

    设置两个布尔数组,记录行和列是否存在0.需要注意的是如何将行或列设为0. void setZeros(vector<vector<int>> &matrix) { in ...

  7. 1:django models

    重温django model 1:many-to-many 的额外属性 一般情况下,many-to-many直接就可以满足我们的要求,考虑这样一种情况: 音乐家和乐团是many-to-many的关系, ...

  8. hdu 3729(二分图最大匹配)

    I'm Telling the Truth Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  9. Longest Substring Without Repeating Characters——经典题

    Given a string, find the length of the longest substring without repeating characters. For example, ...

  10. 【hdoj_2189】来生一起走(母函数)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2189 本题的数学模型如下: 分解的问题,常用母函数求解,这里要求每个"硬币"的价值必须 ...