基于C语言string函数的详解

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;
}

(0)

相关推荐

  • C#中StringBuilder用法以及和String的区别分析

    String类有不可改变性.每次执行字符操作时,都会创建一个新的String对象. StringBuilder 类解决了对字符串进行重复修改的过程中创建大量对象的问题.初始化一个StringBuilder 之后,它会自动申请一个默认的StringBuilder 容量(默认值是16),这个容量是由Capacity来控制的.并且允许,我们根据需要来控制Capacity的大小,也可以通过Length来获取或设置StringBuilder 的长度. 举例: 用String类这么写 复制代码 代码如下:

  • 浅谈C++中的string 类型占几个字节

    在C语言中我们操作字符串肯定用到的是指针或者数组,这样相对来说对字符串的处理还是比较麻烦的,好在C++中提供了 string 类型的支持,让我们在处理字符串时方便了许多. 首先,我写了一段测试代码,如下所示: 复制代码 代码如下: #include <iostream>using namespace std; int main(void){ string str_test1; string str_test2 = "Hello World"; int value1, val

  • 深入C++ string.find()函数的用法总结

    #include <string>#include <iostream>using namespace std; void main(){ 复制代码 代码如下: ////find函数返回类型 size_typestring s("1a2b3c4d5e6f7g8h9i1a2b3c4d5e6f7g8ha9i");string flag;string::size_type position;//find 函数 返回jk 在s 中的下标位置 position = s.f

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

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

  • R语言Legend函数深入详解

    legend(x, y = NULL, legend, fill = NULL, col = par("col"), border = "black", lty, lwd, pch, angle = 45, density = NULL, bty = "o", bg = par("bg"), box.lwd = par("lwd"), box.lty = par("lty"), box.

  • C语言strtod()函数案例详解

    前言 网上有很多关于strtod()函数的文章,不过大部分都是用strtod()函数转换一个字符 char *str = "111.11"; char *target; double ret; ret = strtod(str, &target); 很少有转换字符串的这样的用法 char *p = "111.11 -2.22 Nan nan(2) inF 0X1.BC70A3D70A3D7P+6 1.18973e+4932zzz"; 本文主要参考strtod

  • C语言 TerminateProcess函数案例详解

    TerminateProcess 顾名思义,就是终止进程的意思. 是WindowsAPI的函数, 示例代码如下: // Demo.cpp : 定义控制台应用程序的入口点. //终止进程Demo #include "stdafx.h" using namespace std; //@param:dwpid:指定需要关闭的进程pid int CloseProcess(DWORD dwpid) { HANDLE hProcess = OpenProcess(PROCESS_TERMINATE

  • C语言 bind()函数案例详解

    bind()函数介绍        在建立套接字文件描述符成功后,需要对套接字进行地址和端口的绑定,才能进行数据的接收和发送操作. 函数原型        bind()函数将长度为addlen的struct sockadd类型的参数my_addr与sockfd绑定在一起,将sockfd绑定到某个端口上,如果使用connect()函数则没有绑定的必要.绑定的函数原型如下: #include<sys/types.h> #include<sys/socket.h> int bind(in

  • 基于JS脚本语言的基础语法详解

    JS脚本语言的基础语法:输出语法  alert("警告!");  confirm("确定吗?");   prompt("请输入密码");为弱类型语言: 开始时要嵌入JS代码:<script type="text/javascript"></script>: 关于写程序是需注意的基本语法: 1.所有的字符全都是英文半角的: 2.大部分情况下每条语句结束后要加分号: 3.每一块代码结束后加换行:4.程序前呼

  • C语言fgetc和fputc函数用法详解(以字符形式读写文件)

    在C语言中,读写文件比较灵活,既可以每次读写一个字符,也可以读写一个字符串,甚至是任意字节的数据(数据块).本节介绍以字符形式读写文件. 以字符形式读写文件时,每次可以从文件中读取一个字符,或者向文件中写入一个字符.主要使用两个函数,分别是 fgetc() 和 fputc(). 字符读取函数 fgetc fgetc 是 file get char 的缩写,意思是从指定的文件中读取一个字符.fgetc() 的用法为: int fgetc (FILE *fp); fp 为文件指针.fgetc() 读

  • C语言之system函数案例详解

    来看看在windows操作系统下system () 函数详解(主要是在C语言中的应用) 注意:在windows下的system函数中命令可以不区别大小写! 函数名: system 功 能: 发出一个DOS命令 用 法: int system(char *command); system函数已经被收录在标准c库中,可以直接调用. 例如: #include<stdio.h> #include<stdlib.h> int main() { printf("About to sp

  • C语言之strtol函数用法详解

    strtol 函数用法 strtol是一个C语言函数,作用就是将一个字符串转换为长整型long,其函数原型为: long int strtol (const char* str, char** endptr, int base); 下面我们来看下每个参数的意义: str是要转换的字符 enptr是指向第一个不可转换的字符位置的指针 base的基数,表示转换成为几进制的数 两点注意: 当 base 的值为 0 时,默认采用 10 进制转换,但如果遇到 '0x' / '0X' 前置字符则会使用 16

  • C语言 function recursion函数递归详解

    目录 function recursion(函数递归) 递归的中心思想为: 程序一 递归的两个必要条件 程序一: 程序二: 练习 求n的阶乘 再来道例题 function recursion(函数递归) 函数递归: 是在 一个 过程 或 函数 在其定义或说明中有 直接 或 间接 调用自身 的一种方法 通常把一个 大型复杂的问题 层层 传化 为一个与 原理相似的 ,规模较小 的问题 递归策略 只需 少量的程序 就可以描述出 解题过程 所需的 多次 重复 计算,大大减少了程序的代码量 递归的中心思想

随机推荐