C复习(主要复习)

指针和数组

  • 指针数组是一个数组,数组的每个元素都是指针。它适用于需要存储多个指针的场景,如字符串数组。
  • 数组指针是一个指针,指向一个数组。它适用于需要传递整个数组给函数或处理多维数组的场景。

函数指针:函数指针的定义需要指定函数的返回类型、参数列表以及指针的名称。

//return_type (*pointer_name)(argument_type1, argument_type2, ...);

  • return_type:函数返回值的类型。
  • pointer_name:函数指针的名称。
  • argument_type1, argument_type2, ...:函数参数的类型列表

sizeof和指针与数组

Strlen和字符数组:

  • strlen函数:用于计算字符串的长度,不包括终止符\0。
  • 字符数组:用于存储字符串,必须以\0结尾。

库函数模拟实现手撕Memcopy:

cpp 复制代码
void* my_memcpy(void* dest, const void* src, size_t n) {
    if (dest == nullptr || src == nullptr) {
        return nullptr;
    }

    char* d = static_cast<char*>(dest);
    const char* s = static_cast<const char*>(src);

    // 内存重叠检查
    if (d > s && d < s + n) {
        // 从后向前拷贝
        for (size_t i = n; i != 0; --i) {
            d[i - 1] = s[i - 1];
        }
    }
    else {
        // 正常从前向后拷贝
        for (size_t i = 0; i < n; ++i) {
            d[i] = s[i];
        }
    }

    return dest;
}

实现Mommove:

cpp 复制代码
void* my_memmove(void* destination, const void* source, size_t num) {
    // 如果源和目标指针相同,则无需移动
    if (destination == source) {
        return destination;
    }

    // 将void指针转换为char指针,以便逐字节操作
    char* dest = static_cast<char*>(destination);
    const char* src = static_cast<const char*>(source);

    // 如果源区域在目标区域之前或重叠,则从后向前复制
    if (src < dest && src + num > dest) {
        // 从后向前复制
        for (size_t i = num; i != 0; --i) {
            dest[i - 1] = src[i - 1];
        }
    }
    else {
        // 从前向后复制
        for (size_t i = 0; i < num; ++i) {
            dest[i] = src[i];
        }
    }

    return destination;
}

实现strstr

cpp 复制代码
char* my_strstr(const char* haystack, const char* needle) {
    // 如果needle是空字符串,根据标准定义,返回haystack
    if (*needle == '\0') {
        return const_cast<char*>(haystack);
    }

    // 获取主串和子串的长度
    size_t haystack_len = strlen(haystack);
    size_t needle_len = strlen(needle);

    // 如果子串长度大于主串长度,肯定找不到
    if (needle_len > haystack_len) {
        return nullptr;
    }

    // 遍历主串,寻找子串的起始位置
    for (size_t i = 0; i <= haystack_len - needle_len; ++i) {
        // 比较子串和主串的对应部分
        size_t j = 0;
        while (j < needle_len && haystack[i + j] == needle[j]) {
            ++j;
        }

        // 如果整个子串都匹配,返回匹配的起始位置
        if (j == needle_len) {
            return const_cast<char*>(haystack + i);
        }
    }

    // 如果没有找到子串,返回nullptr
    return nullptr;
}

自定义类型:内存对齐:

大小端的判断:

cpp 复制代码
bool isLittleEndian() {
    union {
        uint32_t i;
        unsigned char c[4];
    } u;

    u.i = 0x01020304;

    // 检查最低地址的字节是否为最低有效字节
    return (u.c[0] == 0x04);
}

int main() {
    if (isLittleEndian()) {
        cout << "系统是小端字节序。" << endl;
    }
    else {
        cout << "系统是大端字节序。" << endl;
    }

    return 0;
}

解释

  • u.i被赋值为0x01020304
  • 如果系统是小端,u.c[0]将是0x04;如果是大端,u.c[0]将是0x01
  • 根据u.c[0]的值判断字节序。

这次是对C中我还不清楚并且比较重要的知识进行总结,顺序可能会有点乱,还请见谅

相关推荐
飞川撸码39 分钟前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习44 分钟前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910132 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
iCxhust2 小时前
Prj10--8088单板机C语言8259测试(1)
c语言·开发语言
亮亮爱刷题2 小时前
算法练习-回溯
算法
眼镜哥(with glasses)3 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
apocelipes6 小时前
Linux c 运行时获取动态库所在路径
linux·c语言·linux编程
int型码农7 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
UFIT7 小时前
NoSQL之redis哨兵
java·前端·算法
喜欢吃燃面8 小时前
C++刷题:日期模拟(1)
c++·学习·算法