自己编写c的字符操作函数strcpy、strcmp、strcat写成头文件mystr.h
也可以编译成静态库 gcc -c mystr.c
生成mystr.o
可以gcc -c test.c mystr.o
也可以打包成库文件:ar crv libmystr.a mystr.o
调用时连接库即可gcc -c test.c -L. -lmystr (-L.是告诉编译器在当前目录(.)找函数库、-lmystr告诉编译器使用名为mystr.a的函数库)
//
代码:
//mystr.h
#ifndef __MYSTR__
#define __MYSTR__
char *str_cpy(char *str,const char *str1)
{
char *s=str;
while(*str1)
{
*s++=*str1++;
}
*s='\0';
return str;
}
int str_cmp(const char *str1,const char *str2)
{
while((*str1) && (*str2) && (*str1==*str2))
{
*str1++;
*str2++;
}
return (int)(*str1-*str2);
}
char *str_cat(char *str1,const char *str2)
{
char *s=str1;
while(*s)
*s++;
while(*str2)
{
*s++=*str2++;
}
*s='\0';
return str1;
}
#endif
编写函数调用:
#include<stdio.h>
#include"mystr.h"
int main()
{
char *str1="hello";
char *str2="world!";
char *ss=str_cpy(str1,str2);
printf("%s\n",ss);
char *sss=str_cat(str1,str2);
printf("%s\n",sss);
int i=str_cmp(str1,str2);
printf("%d\n",i);
return 0;
}
//结果:段错误。。。。
//修改程序:
#include<stdio.h>
#include"mystr.h"
int main()
{
char str1[20]="hello,";
char *str2="world!";
char *ss=str_cpy(str1,str2);
printf("%s\n",ss);
char *sss=str_cat(str1,str2);
printf("%s\n",sss);
int i=str_cmp(str1,str2);
printf("%d\n",i);
return 0;
}
编译运行结果:
world!
world!world!
119
正确。。。。。
分析原因:由于str1指向的地址空间 不足以让str2接到后边。。也就是指针指向不明,地址访问越界出现段错误。应该是这个样子。调用my_cpy( )后str1的值和ss一样都是world!。
总结:在使用指针时(包括传地址)要特别注意指针的指向和空间地址,以防越界。