S
17c最新免费网名:在这个数字时代的个性化签名,你值得拥有!
首页
速度
优化工具
☰
首页
速度
收录
工具
首页
/
速度优化
/
芒果91:解锁舌尖上的热带风情,开启味蕾的奇幻之旅
网站优化
探寻亚洲文化魅力:一场关于“日韩超碰”的深度体验
桃之夭夭,灼灼其华:重温《陈情令》与“小小水蜜桃”的温情回忆
2026-06-08 15:37:59
阅读时长:4分钟
562次阅读
核心内容摘要
青春心跳的奇妙共振:当“女生男生碰碰碰”奏响时代乐章
strstr函数模拟实现
1 函数功能strstr用于在字符串str1中查找子串str2的首次出现位置const char* strstr(const char* str1, const char* str
; char* strstr(char* str1, const char* str
;找到则返回第一次出现的起始地址找不到则返回NULL
2
实现原理场景1简单匹配char arr[] abcdefabcdef; char* p cdef; char* ret my_strstr(arr, p); // 返回 cdefabcdef 的起始地址场景2多次匹配复杂情况str1: abbbcdef\0 str2: bbc\0可能存在多次匹配尝试需要逐字符比较
3 模拟实现代码char* my_strstr(const char* str1, const char* str
{ assert(str1 str
; const char* cur str1; // 当前查找位置 const char* s1 NULL; const char* s2 NULL; while (*cur ! \
{ s1 cur; s2 str2; // 逐字符比较 while (*s1 ! \0 *s2 ! \0 *s1 *s
{ s1; s2; } // 如果str2完全匹配成功 if (*s2 \
{ return (char*)cur; // 返回找到的位置 } cur; // 继续下一个位置 } return NULL; // 未找到 }
memcpy函数模拟实现
1 函数功能void* memcpy(void* destination, const void* source, size_t num);将源内存区域的num个字节拷贝到目标内存区域返回目标空间的起始地址不负责处理重叠内存的拷贝
2
实现原理int arr1[] {1,2,3,4,5,6,7,8,9,10}; int arr2[20] {0}; my_memcpy(arr2, arr12,
; // 拷贝arr1中的3,4,5,6,7内存图示源地址(src): arr12 → 元素3的位置 目标地址(dest): arr2 → 起始位置 拷贝大小: 20字节 (5个int, 假设int为4字节)
3 模拟实现代码void* my_memcpy(void* dest, const void* src, size_t num) { void* ret dest; assert(dest src); // 逐字节拷贝 for (size_t i 0; i num; i) { *(char*)dest *(char*)src; dest (char*)dest 1; src (char*)src 1; } return ret; }
memmove函数模拟实现
1 函数功能void* memmove(void* destination, const void* source, size_t num);与memcpy功能类似但能够处理内存重叠的情况C语言标准规定memcpy负责不重叠内存拷贝memmove负责重叠内存拷贝
2 内存重叠问题int arr1[] {1,2,3,4,5,6,7,8,9,10}; my_memmove(arr1 2, arr1,
; // 将前5个元素拷贝到从索引2开始的位置拷贝前索引: 0 1 2 3 4 5 6 7 8 9 值: 1 2 3 4 5 6 7 8 9 10错误拷贝方式从前向后arr1[2] arr1[0] → 1 arr1[3] arr1[1] → 2 arr1[4] arr1[2] → 1 (已经被覆盖!) arr1[5] arr1[3] → 2 (已经被覆盖!) ...
3 模拟实现代码正确处理重叠void* my_memmove(void* dest, const void* src, size_t num) { void* ret dest; assert(dest src); // 情况1dest在src前面或内存不重叠 → 从前向后拷贝 if (dest src) { char* d (char*)dest; const char* s (const char*)src; while (num--) { *d *s; } } // 情况2dest在src后面有重叠风险 → 从后向前拷贝 else { char* d (char*)dest num - 1; // 指向目标末尾 const char* s (const char*)src num - 1; // 指向源末尾 while (num--) { *d-- *s--; } } return ret; }
关键区别与
总结
1 strstr vs mem系列函数函数操作对象返回类型主要用途strstr字符串char*查找子串memcpy内存块void*非重叠内存拷贝memmove内存块void*任意内存拷贝含重叠
2 memcpy vs memmove标准规定memcpy只需实现不重叠内存拷贝memmove必须处理重叠内存拷贝实际实现某些编译器如VS的memcpy也能处理重叠内存但为保证可移植性重叠时应使用memmove性能考虑不重叠时两者性能相近重叠时memmove会进行方向判断略有开销
3 使用建议查找字符串子串 → 使用strstr拷贝不重叠的内存块 → 使用memcpy性能可能略优不确定内存是否重叠 → 使用memmove更安全需要自己实现时 → 参考上述代码注意处理所有边界情况
完整测试示例#include stdio.h #include string.h #include assert.h // 测试代码 int main() { //
测试my_strstr char str[] abcdefabcdef; char sub[] cdef; char* result my_strstr(str, sub); printf(strstr测试: %s\n, result ? result : 未找到); //
测试my_memcpy int arr1[10] {1,2,3,4,5,6,7,8,9,10}; int arr2[20] {0}; my_memcpy(arr2, arr12,
; printf(memcpy测试: ); for(int i 0; i 5; i) printf(%d , arr2[i]); printf(\n); //
测试my_memmove重叠 int arr3[] {1,2,3,4,5,6,7,8,9,10}; my_memmove(arr32, arr3,
; printf(memmove测试: ); for(int i 0; i 10; i) printf(%d , arr3[i]); printf(\n); return 0; }这些函数是C语言中处理字符串和内存的基础工具理解它们的
实现原理对于深入理解C语言内存管理和字符串操作至关重要。
抖音成人版-抖音成人版应用
相关标签
B与BBBB的奇妙对话:不止是数量的差异,更是身份的进阶
暗夜中的极速流光:解锁免费污污软件最新iOS版v28.8.25的极致午夜美学
刘涛与范冰冰的“风云”对决:谁是娱乐圈的“不老女神”?
欲望的边界与流量的博弈:深挖“小众内容”刷屏背后的社会焦虑
《法国空姐2025版》:一场颠覆想象的飞行体验,免费完整版震撼来袭!
天堂亚洲:感官的盛宴,心灵的栖息地
“搞机time”:科技的“恶心”之美,10分钟体验颠覆想象!
川味“变声”的艺术:BBBB嗓与BBBBB嗓的迷人界限
亚洲成人在线电影精彩纷呈,解锁感官新维度
AAA级体验:不止于电影,更是一种极致追求的生活态度
揭秘“三角洲骇爪翘臀”:一场跨越时空的性感革命
揭秘“仙踪林”与“companylimited”的微妙界限:究竟谁是真正的行业翘楚?
五一的温暖迴响:娜娜老师《家访》2,深入人心的情感之旅
污鱼社:当“污”遇上“趣”,一场颠覆想象的文化探索
🔍
📑
文章目录
二、解锁无限视界:“积积对积积的桶”——免费下载,开启你的数字游乐场!
三、那些年,我们心心念念的“想要”:一场关于渴望的温柔回溯
四、18-XXXXXL19D18内存:突破想象,释放无限潜能
五、困困兔原版视频全部内容
🔥
热门优化文章
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
2026-05-16 23:19:13
DASD-4B-Thinking安全防护配置:保障模型服务稳定运行
2026-05-16 23:19:13
🛠️
实用工具推荐
西方47147:触碰灵魂的艺术,穿越时空的低语
五一假期,台北娜娜《老师2》家访温馨开启,一场跨越时空的教育对话!
相关优化文章 推荐
Clawdbot效果可视化展示:Qwen3:32B Agent执行耗时、Token消耗与缓存命中率仪表盘
2026-06-08 15:37:59 3分钟阅读
Jable视频下载解决方案:轻松获取流媒体内容的实用指南
2026-06-08 15:37:59 6分钟阅读
Cartographer中的分枝定界算法:从论文到代码的完整解析(附避坑指南)
2026-06-08 15:37:59 3分钟阅读
↑
百度百家号客服电话人工服务
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3
1
2
3