手动实现C库字符串常用处理函数

文章目录

  • 前言
  • 一、strlen()
    • 1. 函数原型:
    • 2. 手动实现:
  • 二、strcat()
    • 1. 函数原型:
    • 2. 手动实现:
  • 三、strcpy()
    • 1. 函数原型:
    • 2. 手动实现:
  • 四、strcmp()
    • 1. 函数原型:
    • 2. 手动实现:
  • 五、memset()
    • 1. 函数原型:
    • 2. 手动实现:

前言

      在日常编程中,对于字符串的操作中我们都很习惯的使用一些C库中自带的函数,并且关于字符串的操作函数基本都在 string.h 这个头文件中。关于C库字符串常用处理函数也是平时面试或者考试过程中非常喜欢考的,本文将带大家手动来实现这些常用函数。

一、strlen()

1. 函数原型:

size_t strlen(const char *str)
参数str: 要计算的字符串的长度
返回值: 返回字符串 str 的长度,直到遇到结束字符'\0',但不包括结束字符。
size_t 是一个无符号整数类型。

2. 手动实现:

源代码:

#include 
#include 

size_t my_strlen(const char *str)
{
    size_t len = 0;

    while (*str++ != '\0') {
        len++;
    }

    return len;
}

int main()
{
    char *p = "hello world";
    int len_1 = 0, len_2 = 0;

    len_1 = my_strlen(p);
    len_2 = strlen(p);

    printf("len_1 = %d, len_2 = %d\n", len_1, len_2);

    return 0;
}

运行结果:

len_1 = 11, len_2 = 11

二、strcat()

1. 函数原型:

char *strcat(char *dest, const char *src)
参数1: 目标字符串,该空间需要足够容纳后续追加的字符串。
参数2: 要追加的字符串。
返回值: 返回指向目标字符串的指针。

2. 手动实现:

源代码:

#include 
#include 

char *my_strcat(char *dest, const char *src)
{
    while (*dest != '\0') {
        dest++;
    }

    while (*src != '\0') {
        *dest++ = *src++;
    }

    *dest = '\0';

    return dest;
}

int main()
{
    char p1[20] = "hello ";
    char p2[20] = "hello ";
    char *q = "world";

    my_strcat(p1, q);
    strcat(p2, q);

    printf("p1 = %s, p2 = %s\n", p1, p2);

    return 0;
}

运行结果:

p1 = hello world, p2 = hello world

三、strcpy()

1. 函数原型:

char *strcpy(char *dest, const char *src)
参数1: 要存储的目标字符串。
参数2: 要复制的字符串。
返回值: 返回指向目标字符串的指针。

2. 手动实现:

源代码:

#include 
#include 

char *my_strcpy(char *dest, const char *src)
{
    while (*src != '\0') {
        *dest++ = *src++;
    }

    *dest = '\0';

    return dest;
}

int main()
{
    char p1[20] = {'\0'};
    char p2[20] = {'\0'};
    char *q = "hello world";

    my_strcpy(p1, q);
    strcpy(p2, q);

    printf("p1 = %s, p2 = %s\n", p1, p2);

    return 0;
}

运行结果:

p1 = hello world, p2 = hello world

四、strcmp()

1. 函数原型:

int strcmp(const char *str1, const char *str2)
参数1: 要比较的第一个字符串
参数2: 要比较的第二个字符串
返回值:
	如果返回值 < 0,则表示 str1 小于 str2。
	如果返回值 > 0,则表示 str1 大于 str2。
	如果返回值 = 0,则表示 str1 等于 str2。

2. 手动实现:

源代码:

#include 
#include 

int my_strcmp(const char *str1, const char *str2)
{
    int ret = 0;
    while ((*str1 != '\0') && (*str1 == *str2)) {
        str1++;
        str2++;
    }

    ret = *str1 - *str2;

    return ret;
}

int main()
{
    char p1[20] = {"hello world"};
    char p2[20] = {"hello aorld"};
    int ret_1, ret_2;

    ret_1 = my_strcmp(p2, p1);
    ret_2 = strcmp(p2, p1);

    printf("ret_1 = %d, ret_2 = %d\n", ret_1, ret_2);

    return 0;
}

运行结果:

ret_1 = -22, ret_2 = -22

五、memset()

1. 函数原型:

void *memset(void *str, int c, size_t n)
参数1: 要设置的内存块
参数2: 要填充的值,在填充内存块时是使用该值的无符号字符形式。
参数3: 填充的字符个数。
返回值: 返回指向str的指针。

2. 手动实现:

源代码:

#include 
#include 

void *my_memset(void *str, int c, size_t n)
{
    if (str == NULL) 
        return NULL;

    char *pstr = (char*)str;

    while (n-- > 0) {
        *pstr++ = c ;
    }

    return str;
}

int main()
{
    char p1[20] = {"hello world"};
    char p2[20] = {"hello world"};

    my_memset(p1, '*', 5);
    memset(p2, '*', 5);

    printf("p1 = %s, p2 = %s\n", p1, p2);

    return 0;
}

运行结果:

p1 = ***** world, p2 = ***** world

你可能感兴趣的