目录
strlen函数
用法:char arr[]]="abcde";
用法:判断数组arr中有几个字符!!!
strlen的实现:
my_strlen(str)
{
int index=0;
while(arr!='\0')
{
arr++;
index++
}
return index;
解释:因为数组是以‘\0’来结尾,并且占一个字节的长度,在主函数中创建一个my_strlen()函数,把数组的值放到函数体内即为strlen(arr),这个arr为返回的是这个数组的地址,是arr[0]的地址,在函数体内形式参数str进行接收,这个str是char*类型,str自加不为‘\0’就跳出循环。
strcpy函数
用法:将arr1数组中的内容复制到arr中。
strcpy函数的实现:
char* my_strcpy(char*dest,const char* str) {
assert(dest&&str);//判断dest和str不为‘\0’
char *ret=dest ;
while (*dest++ =*str++)
{c
}
return ret
}
解释:同样,strcpy的两个形式参数需要用char*的类型来表示。我们还要调用assert函数(不要忘了头文件#incude<assert.h>)来判断两个形式参数不为‘\o’.strcp实现的意义是将arr1中的数据按照字符的形式挨个赋值到arr中,但是strcpy是一个不标准的拷贝函数,当arr1定义的数组元素大于需要被拷贝的数组arr时,虽然会提示,但是不会报错,存在溢出现象,倘若想执行标准的字符串拷贝函数请接着往下看>>>>>>>>>>>
strncpy函数
标准的字符串拷贝函数
用法:char* strncpy(char* arr,char* str,size_t num)
strlncpy的实现
#define ikun 20
char* my_strncpy(char* des, const char* src, size_t num)
{
assert(des && src);
char* ps = des;
while (num--)
{
if (*src == '\0')
{
*des++ = '\0';
}
else
*des++ = *src++;
}
return ps;
}
int main()
{
char arr[ikun];
char arr1[] = "1234567890123345678";
my_strncpy(arr, arr1,ikun);
printf("%s\n", arr);
return 0;
}
解释: strncpy与strcpy的原理差不太多,只是他它的形式参数中加了一个为size_t num
这个是啥意思呢?这个是拷贝数组中的几个字符,但是这需要拷贝的第几个字符不能为负数,所以定义为size_t 类型的变量,因为他有了字符的限制,所以它不存在数组越界,所以称他为标准的字符串靠拷贝函数。
strcat函数
用法 char* strcat(char*arr,char*str)
strcat的实现
char* my_strcat(char*dest,const char* str) {
assert(dest&&str);
char *ret=dest ;
while (*dest++ =*str++) {
;
}
return ret;
}
strcat的模拟
char* my_strcat(char*dest,const char* str) {
assert(dest&&str);
char *ret=dest ;
while (*dest++ =*str++) {
;
}
return ret;
}
int main() {
char arr[50] = "hello";
char arr1[50] = " word";
my_strcat(arr+strlen(arr), arr1);
printf("%s", arr);
return 0;
}
解释:这个函数的是想非常容易理解,我们发现这个代码与strcpy函数差不都,只是在后面arr字符串加上了一个strlen(arr),因为他是要在arr1后面的添加,所以,要调过arr个元素的字节。
strstr函数
字符串查找
用法:元素的查找,查找arr1在arr中信息的一一个位置,如果arr不包含arr1,返回NULL
类似于这个表
找到相同的第一个元素
strstr的实现:
#include <stdio.h>
#include <assert.h>
const char* strstr(const char* src, const char* sub)
{
const char *bp;
const char *sp;
if(!src || !sub)
{
return src;
}
while(*src)
{
bp = src;
sp = sub;
do
{
if(!*sp)
return src;
}while(*bp++ == *sp ++);
src ++;
}
return NULL;
}
int main()
{
char p[] = "123456";
char q[] = "23";
char *r = strstr(p,q);
printf("r:%s\n", r);
getchar();
return 0;
}
解释:返回的是匹配成功的字符串以及后面的字符串 ,用于多次匹配知道母串结束。记录子串在母串中出现的次数,找出str2字符串在str1字符串中第一次出现的位置(不包括str2的串结束符)。返回该位置的指针,如找不到,返回空指针指针http://baike.baidu.com/view/159417.htm