原文地址: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. mysql not null default / default

    not null default 说明不能是NULL, 并设置默认值 default 设置默认值 , 但值也可能是NULL mysql> create table test (id int, n ...

  2. libSVM笔记之(一)在matlab环境下安装配置libSVM

    本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing 台湾林智仁教 ...

  3. handle_level_irq 与handle_edge_irq 的区别【转】

    转自:http://blog.csdn.net/xavierxiao/article/details/6087277 版权声明:本文为博主原创文章,未经博主允许不得转载. Linux 里, handl ...

  4. Linux 入门记录:十四、网络基础

    一.IP地址 IP 地址是因特网上的每个网络节点在全球范围内的唯一标识符,一个 IP 地址唯一标识一个主机(严格来说是标识一个网卡接口 network interface card). 现在应用最为广 ...

  5. PXC 避免加入集群时发生SST

    环境 现有集群节点: 192.168.99.210:3101 新加入节点: 192.168.99.211:3101 通过xtrabackup备份还原实例,并通过同步方式追数据: 已有节点情况: roo ...

  6. sicily 1009. Mersenne Composite N

    Description One of the world-wide cooperative computing tasks is the "Grand Internet Mersenne P ...

  7. 【bzoj4562】HAOI2016食物链

    记忆化搜索水过去了…… QwQ #include<bits/stdc++.h> #define N 400010 typedef long long ll; using namespace ...

  8. LeetCode218. The Skyline Problem

    https://leetcode.com/problems/the-skyline-problem/description/ A city's skyline is the outer contour ...

  9. Combination Sum I&&II(经典的回溯算法题)

    I: Given a set of candidate numbers (C) and a target number (T), find all unique combinations in C w ...

  10. JSON优缺点

    总结: 1.占带宽小(格式是压缩的) 2. js通过eval()进行Json读取(便于客户端读取) 3. JSON支持多种语言(c.c++.PHP等),便于服务端解析 JSON (JavaScript ...