基于C语言string函数的详解_C 语言

PS:本文包含了大部分strings函数的说明,并附带举例说明。本来想自己整理一下的,发现已经有前辈整理过了,就转了过来。修改了原文一些源码的问题,主要是用char *字义字符串的问题,导致程序运行时崩溃。另外自己重写了部分测试程序,使其更能满足自己测试的需要。不当之处,还请海涵。
@函数原型:  char *strdup(const char *s)
函数功能:  字符串拷贝,目的空间由该函数分配 
函数返回:  指向拷贝后的字符串指针
参数说明:  src-待拷贝的源字符串
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
#include <alloc.h>
int main()
{
  char *dup_str, *string="abcde";
  dup_str=strdup(string);
  printf("%s", dup_str);
  free(dup_str);
  return 0;
}

@函数名称:  strcpy
函数原型:  char* strcpy(char* str1,char* str2);
函数功能:  把str2指向的字符串拷贝到str1中去
函数返回:  返回str1,即指向str1的指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  char string[10];
  char *str1="abcdefghi";
  strcpy(string,str1);
  printf("the string is:%s\n",string);
  return 0;
}

@函数名称:  strncpy
函数原型:  char *strncpy(char *dest, const char *src,intcount)
函数功能:  将字符串src中的count个字符拷贝到字符串dest中去
函数返回:  指向dest的指针
参数说明:  dest-目的字符串,src-源字符串,count-拷贝的字符个数
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
   char*src = "bbbbbbbbbbbbbbbbbbbb";//20 'b's
   char dest[50] ="aaaaaaaaaaaaaaaaaaaa";//20 'a's

   puts(dest);
   strncpy(dest, src, 10);

   puts(dest); 
   return0;
}

输出:

复制代码 代码如下:

/*******************************************
aaaaaaaaaaaaaaaaaaaa
bbbbbbbbbbaaaaaaaaaa
*******************************************/

注意:strncpy只复制指定长度的字符,不会自动在末尾加'\0'。若指定长度超过源字符串长度,不够的部分补‘\0',
 
@函数名称:  strcat
函数原型:  char* strcat(char * str1,char * str2);
函数功能:  把字符串str2接到str1后面,str1最后的'\0'被取消
函数返回:  str1
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  char buffer[80];
  strcpy(buffer,"Hello ");
  strcat(buffer,"world");
  printf("%s\n",buffer);
  return 0;
}

@函数名称:  strncat
函数原型:  char *strncat(char *dest, const char *src, size_t maxlen)
函数功能:  将字符串src中前maxlen个字符连接到dest中
函数返回:
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
char buffer[80];
int main()
{
  strcpy(buffer,"Hello ");
  strncat(buffer,"world",8);
  printf("%s\n",buffer);
  strncat(buffer,"*************",4);
  printf("%s\n",buffer);
  return 0;
}

注意:与strncpy不同的是,strncat会自动在末尾加‘\0',若指定长度超过源字符串长度,则只复制源字符串长度即停止

@函数名称:  strcmp
函数原型:  int strcmp(char * str1,char * str2);
函数功能:  比较两个字符串str1,str2.
函数返回:  str1<str2,返回负数;str1=str2,返回 0;str1>str2,返回正数. 
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include <string.h>
#include <stdio.h>
int main()
{
  char *buf1="aaa", *buf2="bbb",*buf3="ccc";
  int ptr;
  ptr=strcmp(buf2, buf1);
  if(ptr>0)
    printf("buffer 2 is greater thanbuffer 1\n");
  else
    printf("buffer 2 is less thanbuffer 1\n");
  ptr=strcmp(buf2, buf3);
  if(ptr>0)
    printf("buffer 2 is greater thanbuffer 3\n");
  else
    printf("buffer 2 is less thanbuffer 3\n");
  return 0;
}

@函数名称:  strncmp
函数原型:  int strncmp(char *str1,char *str2,int count)
函数功能:  对str1和str2中的前count个字符按字典顺序比较
函数返回:  小于0:str1<str2,等于0:str1=str2,大于0:str1>str2
参数说明:  str1,str2-待比较的字符串,count-比较的长度
所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
#include<stdio.h>
int main()
{
   char str1[] ="aabbc";//
   char str2[] = "abbcd";//
   //为使测试程序更简练,此处假定了strncmp只返回-1,0,1三个数
   char res_info[] = {'<','=','>'};
   int res;

   //前1个字符比较
   res = strncmp(str1, str2, 1);
   printf("1:str1%c str2\n", res_info[res+1]);

    //前3个字符比较
   res = strncmp(str1, str2, 3);
   printf("3:str1%c str2\n", res_info[res+1]);
}

输出:

复制代码 代码如下:

/****************************************
1:str1= str2
3:str1< str2
*****************************************/

@函数名称:  strpbrk
函数原型:  char *strpbrk(const char *s1, const char *s2)
函数功能:  得到s1中第一个“同时也出现在s2中”字符的位置指针
函数返回:  位置指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
   char *p="Find all vowels";

   p=strpbrk(p+1,"aeiouAEIOU");
   while(p)
   {
      printf("%s\n",p);
      p=strpbrk(p+1,"aeiouAEIOU");

   }
return 0;
}

输出:

复制代码 代码如下:

/**************************************
ind all vowels
all vowels
owels
els
**************************************/

@函数名称:  strcspn
函数原型:  int strcspn(const char *s1, const char *s2)
函数功能:  统计s1中从头开始直到第一个“来自s2中的字符”出现的长度
函数返回:  长度
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
 printf("%d\n",strcspn("abcbcadef","cba"));
 printf("%d\n",strcspn("xxxbcadef","cba"));
 printf("%d\n",strcspn("123456789","cba"));
  return 0;
}

输出:

复制代码 代码如下:

/************************
0
3
9
************************/

@函数名称:  strspn
函数原型:  int strspn(const char *s1, const char *s2)
函数功能:  统计s1中从头开始直到第一个“不来自s2中的字符”出现的长度
函数返回:  位置指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
#include<alloc.h>
int main()
{
   printf("%d\n",strspn("abcbcadef","cba"));
   printf("%d\n",strspn("xxxbcadef","cba"));
   printf("%d\n",strspn("123456789","cba"));
   return 0;
}

输出:

复制代码 代码如下:

/************************
6
0
0
************************/

@函数名称:  strchr
函数原型:  char* strchr(char* str,char ch);
函数功能:  找出str指向的字符串中第一次出现字符ch的位置
函数返回:  返回指向该位置的指针,如找不到,则返回空指针
参数说明:  str-待搜索的字符串,ch-查找的字符
所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
#include<stdio.h>
int main()
{
   char *str = "This is a string!";
   char ch;
   char *p;

   while(1)
   {
      printf("Please input a char:");
      ch = getchar();
      p = strchr(str, ch);
      if(p)
         printf("%c is the %d character of\"%s\"\n",ch, (int)(p-str+1),str);
      else
         printf("Not found!\n");

      printf("Press ESC to quit!\n\n");
      if(27 == getch())
         break;
      fflush(stdin);
   }

  return 0;
}

运行结果:

复制代码 代码如下:

/********************************************
Please input achar:i
i is the 3character of "This is a string!"
Press ESC to quit!

Please input achar:l
Not found!
Press ESC to quit!

Please input achar:s
s is the 4character of "This is a string!"
Press ESC to quit!
**********************************************/

@函数名称:  strrchr
函数原型:  char *strrchr(const char *s, int c)
函数功能:  得到字符串s中最后一个含有c字符的位置指针
函数返回:  位置指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
#include<stdio.h>
int main()
{
  charstring[15];
  char*ptr,c='r';
 strcpy(string,"This is a string");
 ptr=strrchr(string,c);
  if (ptr)
   printf("The character %c is at position:%d",c,ptr-string);
  else
   printf("The character was not found");
  return 0;
}

@函数名称:  strstr
函数原型:  char* strstr(char* str1,char* str2);
函数功能:  找出str2字符串在str1字符串中第一次出现的位置(不包括str2的串结束符)
函数返回:  返回该位置的指针,如找不到,返回空指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
  char*str1="Open Watcom C/C++",*str2="Watcom",*ptr;
 ptr=strstr(str1,str2);
 printf("The substring is:%s\n",ptr);
  return 0;
}

输出:
The substringis:Watcom C/C++

@函数名称:  strrev
函数原型:  char *strrev(char *s)
函数功能:  将字符串中的所有字符颠倒次序排列
函数返回:  指向s的指针 
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
#include<stdio.h>
int main()
{
  char forward[]="string"; //原文中定义为char*是不对的,指向代码段的指针内容是不可变的
 printf("Before strrev():%s",forward);
 strrev(forward);
  printf("Afterstrrev(): %s",forward);
  return 0;
}

输出:

复制代码 代码如下:

/************************************
Beforestrrev():string
After strrev():gnirts
************************************/

@函数名称:  strnset
函数原型:  char *strnset(char *s, int ch, size_t n)
函数功能:  将字符串s中前n个字符设置为ch的值
函数返回:  指向s的指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
   charstring[]="aaaaaaaaaaaaaaaaaaaaaaa";
   char letter='x';
   printf("string before strnset:%s\n",string);
   strnset(string,letter,10);
   printf("string after strnset:  %s\n",string);

return 0;
}

输出:

复制代码 代码如下:

/*************************************************
string beforestrnset: aaaaaaaaaaaaaaaaaaaaaaa
string afterstrnset:  xxxxxxxxxxaaaaaaaaaaaaa
*************************************************/

@函数名称:  strset
函数原型:  char *strset(char *s, int ch)
函数功能:  将字符串s中所有字符设置为ch的值
函数返回:  指向s的指针 
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
  charstring[10]="123456789";
  charsymbol='c';
 printf("Before strset(): %s", string);
 strset(string, symbol);
 printf("After strset(): %s", string);
  return 0;
}

@函数名称: strtok
函数原型:  char *strtok(char *s1, const char *s2)
函数功能:  分解s1字符串为用特定分隔符分隔的多个字符串(一般用于将英文句分解为单词)
函数返回:  字符串s1中首次出现s2中的字符前的子字符串指针
参数说明:  s2一般设置为s1中的分隔字符
        规定进行子调用时(即分割s1的第二、三及后续子串)第一参数必须是NULL
        在每一次匹配成功后,将s1中分割出的子串位置替换为NULL(摘下链中第一个环),因此s1被破坏了
        函数会记忆指针位置以供下一次调用

所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
#include<stdio.h>
int main()
{
  char *p;
  char*buffer;
  char*delims={ " .," };
 buffer=strdup("Find words, all of them.");
 printf("%s\n",buffer);
 p=strtok(buffer,delims);
 while(p!=NULL){
   printf("word: %s\n",p);
   p=strtok(NULL,delims);
  }
 printf("%s\n",buffer);
  return 0;
}//根据测试,可以随时给strtok的第一个参数输入一个新的字符串,开始新字符串的分隔

PS:根据测试,可以随时给strtok的第一个参数输入一个新的字符串,开始新字符串的分隔

@函数名称: strupr
函数原型:  char *strupr(char *s)
函数功能:  将字符串s中的字符变为大写
函数返回:
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  char string[]="abcdefghijklmnopqrstuvwxyz",*ptr; //会影响原字符串的内存,用char[]来声明
  ptr=strupr(string);
  printf("%s",ptr);
  return 0;
}

@函数名称: strlwr
函数原型:  char *strlwr(char *s)
函数功能:  将字符串中的字符变为小写字符
函数返回:  指向s的指针
参数说明:
所属文件:  <string.h>

复制代码 代码如下:

#include<string.h>
int main()
{
  char str[]="HOW TO SAY?";
  printf("%s",strlwr(str));
  return 0;
}

@函数名称: strerror
函数原型:  char *strerror(int errnum)
函数功能:  得到错误信息的内容信息
函数返回:  错误提示信息字符串指针
参数说明:  errnum-错误编号
所属文件:  <string.h>

复制代码 代码如下:

#include <stdio.h>
#include <errno.h>
int main()
{
  char *buffer;
  buffer=strerror(errno);
  printf("Error: %s",buffer);
  return 0;
}

@函数名称: memcpy
函数原型:  void *memcpy(void *dest, const void *src, size_t n)
函数功能:  字符串拷贝
函数返回:  指向dest的指针
参数说明:  src-源字符串,n-拷贝的最大长度
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  char src[]="******************************";
  char dest[]="abcdefghijlkmnopqrstuvwxyz0123456709";
  char *ptr;
  printf("destination before memcpy:%s\n",dest);
  ptr=memcpy(dest,src,strlen(src));
  if (ptr)
    printf("destination after memcpy:%s\n",dest);
  else
    printf("memcpy failed");
  return 0;
}

输出:

复制代码 代码如下:

/*************************************************************
destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123456709
destination after memcpy:******************************456709
**************************************************************/

@函数名称: memccpy
函数原型:  void *memccpy(void *dest, const void *src, int c, size_t n)
函数功能:  字符串拷贝,到指定长度或遇到指定字符时停止拷贝
函数返回:
参数说明:  src-源字符串指针,c-中止拷贝检查字符,n-长度,dest-拷贝底目的字符串指针
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <string.h>
#include <stdio.h>
int main()
{
  char *src="This is the source string";
  char dest[50];
  char *ptr;
  ptr=memccpy(dest,src,'c',strlen(src));
  if (ptr)
  {
    *ptr='\0';
    printf("The character wasfound:%s",dest);
  }
  else
    printf("The character wasn'tfound");
  return 0;
}

输出:

复制代码 代码如下:

/*****************************************
The character was found:This is the sourc
*****************************************/

PS:指定字符被复制到dest中,memccpy返回了dest中指定字符的下一处的地址,返回NULL表示未遇到指定字符
 
@函数名称: memchr
函数原型:  void *memchr(const void *s, int c, size_t n)
函数功能:  在字符串中第开始n个字符中寻找某个字符c的位置
函数返回:  返回c的位置指针,返回NULL时表示未找到
参数说明:  s-要搜索的字符串,c-要寻找的字符,n-指定长度
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <string.h>
#include <stdio.h>
int main()
{
  char str[17];
  char *ptr;
  strcpy(str,"This is a string");
  ptr=memchr(str,'r',strlen(str));
  if (ptr)
  printf("The character 'r' is at position:%d",ptr-str);
  else
  printf("The character was not found");
  return 0;
}

@函数名称: memcmp
函数原型:  int memcmp(const void *s1, const void *s2,size_t n)
函数功能:  按字典顺序比较两个串s1和s2的前n个字节 
函数返回:  <0,=0,>0分别表示s1<,=,>s2
参数说明:  s1,s2-要比较的字符串,n-比较的长度
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main() 

  char *buf1="ABCDE123"; 
  char *buf2="abcde456"; 
  int stat; 
  stat=memcmp(buf1,buf2,5); 
  printf("The strings to position 5 are"); 
  if(stat) printf("not "); 
  printf("the same\n"); 
  return 0; 
}

@函数名称: memicmp
函数原型:  int memicmp(const void *s1, const void *s2, size_t n)
函数功能:  按字典顺序、不考虑字母大小写对字符串s1,s2前n个字符比较
函数返回:  <0,=0,>0分别表示s1<,=,>s2
参数说明:  s1,s2-要比较的字符串,n-比较的长度
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
  char *buf1="ABCDE123";
  char *buf2="abcde456";
  int stat;
  stat=memicmp(buf1,buf2,5);
  printf("The strings to position 5 are");
  if(stat) printf("not");
  printf("the same");
  return 0;
}

输出:

复制代码 代码如下:

/**************************************
The strings to position 5 are the same
***************************************/

@函数名称: memmove
函数原型:  void *memmove(void *dest, const void *src, size_t n)
函数功能:  字符串拷贝
函数返回:  指向dest的指针
参数说明:  src-源字符串,n-拷贝的最大长度
所属文件:  <string.h>,<mem.h>

复制代码 代码如下:

#include <string.h>
#include <stdio.h>
int main()
{
  chardest[40]="abcdefghijklmnopqrstuvwxyz0123456789";
  printf("destination prior tomemmove:%s\n",dest);
  memmove(dest+1,dest,35);
  printf("destination aftermemmove:%s",dest);
  return 0;
}

PS:与memcpy不同的是,memmove可以处理目的字符串与源字符串地址空间出现重叠的情况,可保证待复制的内容不被破坏。
@函数名称:  memset
函数原型:   void *memset(void *s, int c, size_t n)
函数功能:   字符串中的n个字节内容设置为c
函数返回:
参数说明:   s-要设置的字符串,c-设置的内容,n-长度
所属文件:   <string.h>,<mem.h>

复制代码 代码如下:

#include <string.h>
#include <stdio.h>
#include <mem.h>
int main()
{
  charbuffer[]="Hello world";
 printf("Buffer before memset:%s/n",buffer);
 memset(buffer,'*',strlen(buffer)-1);
 printf("Buffer after memset:%s",buffer);
  return 0;
}

时间: 2024-10-30 10:42:52

基于C语言string函数的详解_C 语言的相关文章

C语言柔性数组实例详解_C 语言

本文实例分析了C语言柔性数组的概念及用法,对于进一步学习C程序设计有一定的借鉴价值.分享给大家供大家参考.具体如下: 一般来说,结构中最后一个元素允许是未知大小的数组,这个数组就是柔性数组.但结构中的柔性数组前面必须至少一个其他成员,柔性数组成员允许结构中包含一个大小可变的数组,sizeof返回的这种结构大小不包括柔性数组的内存.包含柔数组成员的结构用malloc函数进行内存的动态分配,且分配的内存应该大于结构的大小以适应柔性数组的预期大小.柔性数组到底如何使用? 不完整类型 C和C++对于不完

贪心算法的C语言实现与运用详解_C 语言

贪心算法 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解. 贪心算法不是对所有问题都能得到整体最优解,但对范围相当广泛的许多问题他能产生整体最优解或者是整体最优解的近似解.贪心算法的基本思路如下: 1.建立数学模型来描述问题. 2.把求解的问题分成若干个子问题. 3.对每一子问题求解,得到子问题的局部最优解. 4.把子问题的解局部最优解合成原来解问题的一个解.   实现该算法的过程: 从问题的某一初始解出

C++的get()函数与getline()函数使用详解_C 语言

C++ get()函数读入一个字符 get()函数是cin输入流对象的成员函数,它有3种形式:无参数的,有一个参数的,有3个参数的. 1) 不带参数的get函数 其调用形式为 cin.get() 用来从指定的输入流中提取一个字符(包括空白字符),函数的返回值就是读入的字符. 若遇到输入流中的文件结束符,则函数值返回文件结束标志EOF(End Of File),一般以-1代表EOF,用-1而不用0或正值,是考虑到不与字符的ASCII代码混淆,但不同的C ++系统所用的EOF值有可能不同. [例]

C语言中的sscanf()函数使用详解_C 语言

sscanf() - 从一个字符串中读进与指定格式相符的数据. 函数原型: Int sscanf( string str, string fmt, mixed var1, mixed var2 ... ); int scanf( const char *format [,argument]... ); 说明: sscanf与scanf类似,都是用于输入的,只是后者以屏幕(stdin)为输入源,前者以固定字符串为输入源. 其中的format可以是一个或多个 {%[*] [width] [{h |

C++中memset函数用法详解_C 语言

本文实例讲述了C++中memset函数用法.分享给大家供大家参考,具体如下: 功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作 用 法: void memset(void *s, char ch, unsigned n); 程序示例: #include <string.h> #include <stdio.h> #include <memory.h> int main(v

C语言函数语法详解_C 语言

1.概述         在C语言中,函数是来完成子程序或者某个模块的功能.有主程序或者其他函数调用,其他函数之间可以相互调用.同一函数可以被一个或多个函数任意次调用. 注意:     a.一个C程序有一个或多个程序模块组成,每一个程序模块作为一个源程序文件.一个源文件可以为多个C程序共用.     b.程序在编译时是以源文件为单位进行编译,而不是以函数为单位进行编译.一个源文件就是一个编译单元     c.C程序的执行是从main函数开始,也是在main函数中结束整个程序     d.所有函数

C语言关系运算符实例详解_C 语言

在程序中经常需要比较两个数据的大小,以决定程序下一步的工作.比如一个程序限制了只能成年人使用,儿童因为年龄不够,没有权限使用.这时候程序就需要获取用户输入的年龄并做出判断,如果超过18岁就正常运行,否则给出无权使用的提示. 比较两个数据大小的运算符称为关系运算符(Relational Operators). 在C语言中有以下关系运算符: 1) <(小于) 2) <=(小于或等于) 3) >(大于) 4) >=(大于或等于) 5) ==(等于) 6) !=(不等于) 关系运算符都是双

C语言for语句用法详解_C 语言

首先,这里所提到的类C语言指的是如C.C++.C#和Java等语法和C语言一样或类似的程序设计语言.这些语言中,for语句的语法和执行流程都是一样的.本文将就这一语句的用法进行一个较为深入的讨论. for语句: 复制代码 代码如下: for (表达式1;表达式2;表达式3) {   循环语句 } 表达式1 给循环变量赋初值 表达式2 为循环条件 表达式3 用来修改循环变量的值,称为循环步长. for语句的执行流程: 例:编程计算:1+2+3+...+99+100的结果. 这是累加问题,累加问题的

基于linux下获取时间函数的详解_C 语言

//-------------------------------------------------------------//asctime(将时间和日期以字符串格式表示)#include<time.h>定义函数char * asctime(const struct tm * timeptr);函数说明asctime()将参数timeptr所指的tm结构中的信息转换成真实世界所使用的时间日期表示方法,然后将结果以字符串形态返回.此函数已经由时区转换成当地时间,字符串格式为:"We