C语言中strlen() strcpy() strcat() strcmp()函数的实现方法

 更新时间:2017年08月07日 16:26:44   作者:晓百  
这篇文章主要介绍了C语言中strlen() strcpy() strcat() strcmp()函数的实现方法,需要的朋友可以参考下

strlen函数原型:unsigned int strlen(const char *);返回的是字符串中第一个\0之前的字符个数。

  1.strcat函数原型char* strcat(char* dest,const char* src); 进行字符串的拼接,将第二个字符串连接到第一个字符串中第一个出现\0开始的地方。返回的是拼接后字符的首地址。并不检查第一个数组的大小是否可以容纳第二个字符串。如果第一个数组的已分配的内存不够容纳第二个字符串,则多出来的字符将会溢出到相邻的内存单元。

  2.strncat函数原型:strncat(dest,src,maxsize)功能跟strcat一致,不过它带有一个maxsize的参数,设置容纳的最大的字符长度。如在遇到\0之前达到了最大字符长度,则会只连接最大字符长度个数的字符。

  3.strcpy函数原型 char* strcpy(char* dest,const char* src); 将第二个字符串\0之前的字符复制到第一个内存地址内。返回的是复制后的字符串的首地址。有char*返回值是为了函数能够支持链式表达式,增加了函数的“附加值”。 char a[7]="abcdef",char b[5]="xyz";

strcpy(a,b)函数 当将后面的数组赋值给前面那个时侯 除去五个元素后,从下标为5开始的元素仍旧是之前a[5]的元素。

  4.strncpy(str1,str2,numbe)函数是将str2中的前number个字符赋给str1,或是将\0之前的字符赋给str1.

  5.strcmp函数原型 int strcmp(const char *src1,const char* src2);进行两个字符串中从第一个开始的ASCII码的比较。遇到\0或者不一致时退出,如果前者大于后者返回1,小于返回-1 如果在两个中的任何一个的\0之前都保持一致,则返回0. 当src或src遇到\0时即停止比较.strcmp比较的是字符串,不是字符,字符之间的比较可以直接用==

  6.strncmp(str1,str2,numbe)函数在strcmp的基础上多了一个int参数,即指定比较前几个字符是否相等。

注意:对于strcat函数和strcpy函数并没有进行边界大小的限定,所以在用时要注意是否足够内存。

对于内存问题:用memcpy函数更为安全。

memcpy函数原型void * memcpy(void *desc,const char* src,unsigned int count);相对于strcpy函数,memcpy函数并不是将\0前面的字符复制给desc,而是将前count个字符进行复制。

memcmp函数,函数原型: int memcmp(void *buf1, void *buf2, unsigned int count);也是对两个字符串之前的count个字符进行比较。

例子:

#include<stdio.h>
#include<assert.h>
//strlen
unsigned int strlenght(const char* src)
{
 unsigned int len=0;
 assert(src!=0);
 while(*src++)
 {
  len++;
 }
 return len;
}
//strcat
char* strlink(char* dest,char* src)
{
 char *tmp=dest;
 assert((dest!= NULL)&&(src!=NULL));
 while(*dest++);
 *dest--;
 while(*dest++=*src++);
  return tmp;
}
//strcpy
char* strcopy(char* dest,const char* src)
{
 char *tmp=dest;
 assert((dest!=NULL)&&(src!=NULL));
 while(*src)
 {
  *dest++=*src++;
 }
 *dest='\0';
 return tmp;
}
//strcmp
int strcompare(const char* src1,const char* src2)
{
 int x=0;
 while(!(x = *src1-*src2) && *src1)
 {
  src1++;
  src2++;
 }
 if(x>0)
  x = 1;
 if(x<0)
  x = -1;
 return x;
}
void main()
{
 char arr[100] = "It's wonderful weather!!";
 char arr1[20] = "I am\0 fine!";
 char *arr2;
 printf("%s的长度为:%d\n",arr,strlenght(arr));
 printf("%s的长度为:%d\n",arr1,strlenght(arr1));
 arr2 = strlink(arr,arr1);
 printf("%s\n%s\n",arr2,arr);
 printf("%s %s\n %d\n",arr1,arr,strcompare(arr1,arr));
 printf("%s\n%s\n",arr,strcopy(arr,arr1));
}

总结

以上所述是小编给大家介绍的C语言中strlen() strcpy() strcat() strcmp()函数的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • 使用C语言实现vector动态数组的实例分享

    使用C语言实现vector动态数组的实例分享

    vector是指能够存放任意类型的动态数组,而C语言中并没有面向对象的C++那样内置vector类,所以我们接下来就来看一下使用C语言实现vector动态数组的实例,需要的朋友可以参考下
    2016-05-05
  • break的使用for循环嵌套示例

    break的使用for循环嵌套示例

    这篇文章主要介绍了break的使用for循环嵌套示例,需要的朋友可以参考下
    2014-02-02
  • 详解C++ STL模拟实现vector

    详解C++ STL模拟实现vector

    这篇文章主要为大家详细介绍了C++如何模拟实现STL容器vector,文中的示例代码讲解详细,对我们学习C++有一定帮助,需要的可以参考一下
    2023-01-01
  • C++ BloomFilter布隆过滤器应用及概念详解

    C++ BloomFilter布隆过滤器应用及概念详解

    布隆过滤器是由布隆(Burton Howard Bloom)在1970年提出的 一种紧凑型的、比较巧妙的概率型数据结构,特点是高效地插入和查询,可以用来告诉你 “某样东西一定不存在或者可能存在”,它是用多个哈希函数,将一个数据映射到位图结构中
    2023-03-03
  • QT中线程池QThreadPool类概念和使用方法详解

    QT中线程池QThreadPool类概念和使用方法详解

    这篇文章主要为大家介绍了QT中线程池QThreadPool类概念和使用方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 一波二叉树遍历问题的C++解答实例分享

    一波二叉树遍历问题的C++解答实例分享

    这篇文章主要介绍了一波二叉树遍历问题的C++解答实例分享,包括节点打印和转换为镜像等问题的解答,需要的朋友可以参考下
    2016-02-02
  • C语言数据结构之单链表的实现

    C语言数据结构之单链表的实现

    链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。本文将用C语言实现单链表,需要的可以参考一下
    2022-06-06
  • C++详细讲解IO流原理

    C++详细讲解IO流原理

    当程序与外界进行信息交换时,存在两个对象,一个是程序中的对象,另一个是文件对象。流是信息流动的一种抽象,它负责在数据的生产者和数据的消费者之间建立联系,并管理数据的流动
    2022-05-05
  • C++实现统计代码运行时间的示例详解

    C++实现统计代码运行时间的示例详解

    这篇文章主要为大家详细介绍了C++一个有趣的小项目——统计代码运行时间,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-05-05
  • C语言qsort函数使用方法详解

    C语言qsort函数使用方法详解

    qsort是一个库函数,基于快速排序算法实现的一个排序的函数,下面这篇文章主要给大家介绍了关于C语言qsort()函数使用的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09

最新评论