【C语言】 字符串操作函数及内存拷贝函数归总

今天在这里把零散的一些常用的字符串操作函数和内存拷贝函数进行一下归总实现。


一 . 字符串操作函数

字符串操作函数有很多,这里我列举一些常用的函数,以及自实现的代码:

字符串拷贝函数:

函数原型:

char* my_strcpy(char* dst,const char* src)

strcpy():

char* my_strcpy(char* dst,const char* src)
{
    assert(dst);
    assert(src);

    char *ret = dst;  //把首地址保存起来,因为下面会修改dst
    while (*dst++ = *src++)
        ;

    return ret;
}

函数原型:

char* my_strncpy(char* dst,const char* src,int n)

strncpy():

char* my_strncpy(char* dst,const char* src,int n)
{
    assert(dst);
    assert(src);

    char* ret = dst;
    while (n--)
    {
        *dst++ = *src++;
    }

    return ret;
}

字符串追加函数:

函数原型:

char* my_strcat(char* dst,const char* src)

strcat():

char* my_strcat(char* dst,const char* src)
{
    assert(dst);
    assert(src);

    char *ret = dst;

    while (*dst) 
        dst++;

    while (*dst++ = *src++)
        ;

    return ret;
}

函数原型:

char* my_strncat(char *dst, const char *src, int n)

strncat():

char* my_strncat(char *dst, const char *src, int n)
{
    assert(dst);
    assert(src);

    char *ret = dst;
    while (*dst)
        dst++;
    while (n--)
    {
        *dst++ = *src++;
    }

    return ret;
}

字符串比较函数:

函数原型:

int my_strcmp(const char* dst,const char* src)

strcmp():

int my_strcmp(const char* dst,const char* src)
{
    assert(dst);
    assert(src);

    while ((*dst == *src) && *dst && *src)
    {
        dst++;
        src++;
        if (*dst == 0 && *src == 0)
        {
            return 1;
        }
    }

    return -1;
}

函数原型:

int my_strncmp(char* dst, const char* src, int n)

strncmp():

int my_strncmp(char* dst, const char* src, int n)
{
    assert(dst);
    assert(src);

    while (n--)
    {
        if ((*dst == *src) && *dst && *src)
        {
            dst++;
            src++;
        }
        else
        {
            return -1;
        }

        if (*dst == 0 && *src == 0) // 全部相同时的处理情况
        {
            return 1;
        }
    }    

    return 1; // 部分相同时的处理情况
}

查找子字符串函数:

函数原型:

char* my_strtsr(char* str1, char* str2)

strstr():

char* my_strtsr(char* str1, char* str2)
{
    assert(str1); // 原串
    assert(str2); // 子串

    char* s1 = str1;
    char* s2 = str2;
    char* s = str2; // 保存子串的首地址

    if (*s1 == 0)
    {
        if (*s2)
            return NULL;

        return s;
    }

    while (*s1 && *s2)
    {
        if (*s1 != *s2)
        {
            s1++;
        }
        if (*s1 == *s2)
        {
            s1++;
            s2++;
        }
        if (*s1 != *s2) 
        {
            if (*s1 == 0)
            {
                return NULL;
            }
            else if (*s2 == 0)
            {
                return s;
            }

            s2 = s; //若*s1和s2不相等,则让子串重新从头开始
        }    
    }

    return NULL;
}



二 . 内存拷贝函数

内存拷贝函数这里罗列出 memcpy() 以及解决内存拷贝时重叠的问题的函数 memmove() ,附带写出内存初始化函数memset() .

内存拷贝函数:

函数原型:

void* my_memcpy(void *dt,const void *src,size_t count)

memcpy():

void* my_memcpy(void *dst,const void *src,size_t count)
{
    assert(dst);
    assert(src);

    char *pDst = (char*)dst;
    char *pSrc = (char*)src;
    char *ret = (char*)dst; // 保存dst首地址

    while (count--)
    {
        *pDst++ = *pSrc++;
    }

    return ret;
}

解决内存拷贝时 的内存重叠问题的函数:

函数原型:

void* my_memmove(void *p1,void *p2,size_t count)

memmove():

void* my_memmove(void *p1,void *p2,size_t count)
{
    // 在一个数组中进行
    assert(p1);
    assert(p2);

    char *dst = (char*)p1;
    char *src = (char*)p2;
    char *ret = (char*)p1; // 保存首地址

    if (dst > src && (dst < src + count)) // 判断内存重叠情况
    {
        while (count--)
        {
            *(dst + count) = *(src + count);
        }
    }
    else // 不重叠情况
    {
        while (count--)
        {
            *dst++ = *src++;
        }
    }

    return ret;
}

内存初始化函数:

函数原型:

void* my_memset(void* arr,int c,size_t size)

memset():

void* my_memset(void* arr,int c,size_t size)
{
    assert(arr);

    char* dst = (char*)arr;
    int i = 0;
    for (i = 0; i < size; i++)
    {
        *(dst + i) = c;
    }

    return arr;
}

附源代码及测试代码:

#include <stdio.h>
#include <assert.h>
#include <stdlib.h>

char* my_strcpy(char* dst,const char* src)
{
    assert(dst);
    assert(src);

    char *ret = dst;  //把首地址保存起来,因为下面会修改dst
    while (*dst++ = *src++)
        ;

    return ret;
}

char* my_strncpy(char* dst,const char* src,int n)
{
    assert(dst);
    assert(src);

    char* ret = dst;
    while (n--)
    {
        *dst++ = *src++;
    }

    return ret;
}

char* my_strcat(char* dst,const char* src)
{
    assert(dst);
    assert(src);

    char *ret = dst;

    while (*dst) 
        dst++;

    while (*dst++ = *src++)
        ;

    return ret;
}

char* my_strncat(char *dst, const char *src, int n)
{
    assert(dst);
    assert(src);

    char *ret = dst;
    while (*dst)
        dst++;
    while (n--)
    {
        *dst++ = *src++;
    }

    return ret;
}

int my_strcmp(const char* dst,const char* src)
{
    assert(dst);
    assert(src);

    while ((*dst == *src) && *dst && *src)
    {
        dst++;
        src++;
        if (*dst == 0 && *src == 0)
        {
            return 1;
        }
    }

    return -1;
}

int my_strncmp(char* dst, const char* src, int n)
{
    assert(dst);
    assert(src);

    while (n--)
    {
        if ((*dst == *src) && *dst && *src)
        {
            dst++;
            src++;
        }
        else
        {
            return -1;
        }

        if (*dst == 0 && *src == 0) // 全部相同时的处理情况
        {
            return 1;
        }
    }    

    return 1; // 部分相同时的处理情况
}

char* my_strtsr(char* str1, char* str2)
{
    assert(str1); // 原串
    assert(str2); // 子串

    char* s1 = str1;
    char* s2 = str2;
    char* s = str2; // 保存子串的首地址

    if (*s1 == 0)
    {
        if (*s2)
            return NULL;

        return s;
    }

    while (*s1 && *s2)
    {
        if (*s1 != *s2)
        {
            s1++;
        }
        if (*s1 == *s2)
        {
            s1++;
            s2++;
        }
        if (*s1 != *s2)
        {
            if (*s1 == 0)
            {
                return NULL;
            }
            else if (*s2 == 0)
            {
                return s;
            }

            s2 = s;
        }    
    }

    return NULL;
}

void* my_memcpy(void *dst,const void *src,size_t count)
{
    assert(dst);
    assert(src);

    char *pDst = (char*)dst;
    char *pSrc = (char*)src;
    char *ret = (char*)dst; // 保存dst首地址

    while (count--)
    {
        *pDst++ = *pSrc++;
    }

    return ret;
}

void* my_memmove(void *p1,void *p2,size_t count)
{
    // 在一个数组中进行
    assert(p1);
    assert(p2);

    char *dst = (char*)p1;
    char *src = (char*)p2;
    char *ret = (char*)p1; // 保存首地址

    if (dst > src && (dst < src + count)) // 判断内存重叠情况
    {
        while (count--)
        {
            *(dst + count) = *(src + count);
        }
    }
    else // 不重叠情况
    {
        while (count--)
        {
            *dst++ = *src++;
        }
    }

    return ret;
}

void* my_memset(void* arr,int c,size_t size)
{
    assert(arr);

    char* dst = (char*)arr;
    int i = 0;
    for (i = 0; i < size; i++)
    {
        *(dst + i) = c;
    }

    return arr;
}

void test1()
{
    char a1[10] = { 0 };
    char a2[] = "world";

    printf("%s", my_strcpy(a1, a2));
    printf("\n");
}

void test2()
{
    char a1[15] = "hello";
    char a2[] = " world";

    printf("%s",my_strcat(a1,a2));
    printf("\n");
}

void test3()
{
    char a1[] = "abcdef";
    char a2[] = "abcdef";
    printf("%d\n",my_strcmp(a1,a2));
}

void test4()
{
    char a1[10] = "hello";
    char a2[] = " world";

    printf("%s",my_strncat(a1,a2,4));
    printf("\n");
}

void test5()
{
    int a1[10] = {1,2,3,4,5,6,7,8,9,10};
    int a2[10];
    int i = 0;

    my_memcpy(a2,a1,4);
    for (i = 0; i < 10;i++)
    {
        printf("%d ", a2[i]);
    }
    printf("\n");
}

void test6()
{
    int a[10] = {1,2,3,4,5,6,7,8,9,10};
    int i = 0;

    my_memmove(a+2,a+5,4);
    for (i = 0; i < 10;i++)
    {
        printf("%d ",a[i]);
    }
    printf("\n");
}

void test7()
{
    char a1[10] = { 0 };
    char a2[] = "world";

    printf("%s", my_strncpy(a1, a2, 3));
    printf("\n");
}

void test8()
{
    char a1[] = "abcdef";
    char a2[] = "acb";

    printf("%d\n", my_strncmp(a1, a2, 2));
}

void test9()
{
    char* a1 = "abccddefgh";
    char* a2 = "cddef";

    printf("%s",my_strtsr(a1,a2));
    printf("\n");
}

void test10()
{
    int arr[10];
    int i = 0;
    my_memset(arr, 0, 32);
    for (i = 0; i < 10; i++)
        printf("%d ",arr[i]);
    printf("\n");
}

int main()
{
    test1();
    test2();
    test3();
    test4();
    test5();
    test6();
    test7();
    test8();
    test9();
    test10();

    system("pause");
    return 0;
}

若有纰漏,欢迎指正。

时间: 2024-11-19 19:01:32

【C语言】 字符串操作函数及内存拷贝函数归总的相关文章

[C] 语言字符串、文件及内存分配函数

一.字符串函数 1.gets() 头文件:#include <stdio.h> 函数原型:char *gets(char *string); 函数说明:从标准输入流(stdin)中读取整行,直至遇到换行符结束,然后丢弃换行符,储存其余字符,并在末尾加上空字符,表示一个字符串: 函数返回值:若成功则返回指向string的指针,否则返回NULL: 备注:与puts()函数配套使用:只知道string的开始出,不知道数组中有多少个元素,超出边界,容易造成缓冲区溢出. 2.fgets() 头文件:in

转:C语言字符串操作函数 - strcpy、strcmp、strcat、反转、回文

转自:C语言字符串操作函数 - strcpy.strcmp.strcat.反转.回文 作者:jcsu C语言字符串操作函数 1. 字符串反转 - strRev2. 字符串复制 - strcpy3. 字符串转化为整数 - atoi4. 字符串求长 - strlen5. 字符串连接 - strcat6. 字符串比较 - strcmp7. 计算字符串中的元音字符个数8. 判断一个字符串是否是回文1. 写一个函数实现字符串反转 版本1 - while版 void strRev(char *s){    

C语言字符串操作

C语言字符串操作函数 1.strlen strlen用于求一个C风格字符串的长度,函数原型为 #include <string.h> size_t strlen(const char *s); 返回值为字符串的长度,当遇到'\0'时,认为字符串结束,'\0'不算入长度中. #include <stdio.h> #include <string.h> int main(void) { char *str = "hello,world"; int cou

C语言字符串操作大全

转载自:C语言字符串操作总结大全(超详细) 1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度字符串 strlen(p) 取字符串长度 strcmp(p, p1) 比较字符串 strcasecmp忽略大小写比较字符串strncmp(p, p1, n) 比较指定长度字符串 strchr(p, c) 在字符串中查找指定字符 strrchr(p, c)

c++中内存拷贝函数(C++ memcpy)详解

原型:void*memcpy(void*dest, const void*src,unsigned int count); 功能:由src所指内存区域复制count个字节到dest所指内存区域. 说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针. 举例: // memcpy.c #include <stdlib.h> #include <string.h> main() { char *s= "Golden Global View "; c

C语言字符串操作函数整理

#include<stdio.h> #include<string.h> #include<stdlib.h> int main() {     char *str1="hello world!";     char *str2="HELLO WORLD!";     int len=strlen(str1);//求的字符串长度,不包括'\0'在内     printf("len=%d\n",len);    

C语言字符串操作总结大全(超详细)

1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度字符串 strlen(p) 取字符串长度 strcmp(p, p1) 比较字符串 strcasecmp忽略大小写比较字符串strncmp(p, p1, n) 比较指定长度字符串 strchr(p, c) 在字符串中查找指定字符 strrchr(p, c) 在字符串中反向查找 strstr(p, p1

面试之C语言字符串操作总结大全(转载)

趁着十一就好好补补数据结构吧,通信这个不软不硬的专业,现在还是得好好学学补习补习,,你这个非211的本科生!虽然拿到了一个offer,但是觉得时间还有,得继续拼一拼,希望不辜负! 1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度字符串 strlen(p) 取字符串长度 strcmp(p, p1) 比较字符串 strcasecmp忽略大小写比较字符

C语言 字符串操作两头堵模型

//字符串操作两头堵模型练习 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<string.h> //去除字符串中的空格 //const char *pin的解释:const char *pin是用来限制指针pin指向的数据是个常量,不允许在常量中修改, //但是并不限制实参指针指向的数据也必须是一个常量 //这是为了防止传过来的参数pin所指向的数据不可以修改,