在linux C 编程中,我们经常遇到字符串的处理,最多的就是字符串的长度、拷贝字符串、比较字符串等;当然现在的C库中为我们提供了很多字符串处理函数。熟练的运用这些函数,可以减少编程工作量,这里介绍几个常用的字符串函数,并编写一些程序,如果没有这些库函数,我们将如何实现其功能;
1 求字符串长度函数 strlen
头文件:string.h
函数原型:size_t strlen(const char *s)
功能:求字符串长度(不含字符串结束标志'\0')
如果没有这个函数,我们如何实现strlen呢?
程序如下:
#include <stdio.h>
#include <string.h>
int mystrlen(const char *p)
{
int i = 0;
while(p[i])
i++;
return i;
}
int main()
{
int len;
char str[] = "Helloworld";
len = mystrlen(str);
printf("len = %d\n",len);
return 0;
}
执行结果如下:
fs@ubuntu:~/qiang/string$ gcc -o strlen strlen.c
fs@ubuntu:~/qiang/string$ ./strlen
len = 10
同样可以实现求字符串长度功能。
既然在讲strlen(),在这里多说明一下,注意strlen()与sizeof()的区别:
sizeof和strlen有以下区别:
sizeof是一个操作符,strlen是库函数。
sizeof的参数可以是数据的类型,也可以是变量,而strlen只能以结尾为‘\0‘的字符串作参数。
编译器在编译时就计算出了sizeof的结果。而strlen函数必须在运行时才能计算出来。并且sizeof计算的是数据类型占内存的大小,而strlen计算的是字符串实际的长度。
数组做sizeof的参数不退化,传递给strlen就退化为指针了。
注意:有些是操作符看起来像是函数,而有些函数名看起来又像操作符,这类容易混淆的名称一定要加以区分,否则遇到数组名这类特殊数据类型作参数时就很容易出错。最容易混淆为函数的操作符就是sizeof。
说明:指针是一种普通的变量,从访问上没有什么不同于其他变量的特性。其保存的数值是个整型数据,和整型变量不同的是,这个整型数据指向的是一段内存地址。
2、字符串拷贝函数strcpy()
头文件:string.h
函数原型:char *strcpy(char *dest,const char *src)
功能: 字符串拷贝
参数:src为源串的起始地址,dest为目标串的起始地址
如果没有这个函数,我们将如何实现呢?程序如下:
#include <stdio.h>
char *mystrcpy(char *dest,const char *src)
{
char *p;
p = dest;
while(*src)
{
*dest++ = *src++;
}
*dest = '\0';
return p;
}
int main()
{
const char str1[] = "Helloworld";
char str2[30];
mystrcpy(str2,str1);
printf("str2 = %s\n",str2);
return 0;
}
执行结果如下:
fs@ubuntu:~/qiang/string$ ./strcpy
str2 = Helloworld
同样能够得到结果,当然有了strcpy()会很方便;
3、字符串连接接函数strcat
头文件:string.h
函数原型:char *strcat(char *dest,const char *src)
功能:把字符串src连接到字符串dest的后面
实现方法:
#include <stdio.h>
char *mystrcat(char *dest,const char *src)
{
char *p;
p = dest;
while(*dest)
dest++;
while(*src)
{
*dest++ = *src++;
}
*dest = '\0';
return p;
}
int main()
{
char str1[] = "hello";
char str2[] = "world";
mystrcat(str1,st