c语言重要的字符串与内存函数
作者:qq_59078816 发布时间:2023-04-28 00:35:42
一.字符串函数
1. 求字符串长度的strlen
size_t strlen ( const char * str );
字符串以 ‘\0' 作为结束标志,strlen函数返回的是在字符串中 ‘\0' 前面出现的字符个数(不包含 ‘\0' )。
参数指向的字符串必须要以 ‘\0' 结束。
注意函数的返回值为size_t,是无符号的。
模拟实现strlen
size_t my_strlen(const char*str)
{
size_t count=0;
while(*str)
{
str++;
count++;
}
2.比较字符串大小的strcmp
int strcmp ( const char * str1, const char * str2 );
从str1和str2指向的位置开始比较,如果遇到两个不相等的字符或者\0函数结束并且返回值。
第一个字符串的字符大于第二个字符串的字符返回 >0的数字。
第一个字符串的字符等于第二个字符串的字符返回 =0的数字。
第一个字符串的字符小于第二个字符串的字符返回 <0的数字。
模拟实现strcmp
int my_strcmp(const char*str1,const char*str2)
{
while (*str1 == *str2)
{
if (*str1 && *str2)//判断'\0'
return *s2 - *s1;
*str1++;
*str2++;
}//循环结束标志*str1!=*str2
return *str2 - *str1;
}
3.复制字符串的strcpy
char* strcpy(char * destination, const char * source)
拷贝source
到destination
中,返回一个指向dest的char* 的指针。
源字符串必须以 ‘\0' 结束。
会将源字符串中的 ‘\0' 拷贝到目标空间。
目标空间必须足够大,以确保能存放源字符串。
目标空间必须可变。
模拟实现strcpy
char *my_strcpy(char *dest, const char*src)
{
char *ret = dest;
while((*dest++ = *src++))
{
;
}
return ret;
}
4.追加字符串的strcat
char * strcat ( char * destination, const char * source );
从dest的末尾 ‘\0'开始添加src直到‘\0'
源字符串必须以 ‘\0' 结束。
目标空间必须有足够的大,能容纳下源字符串的内容。
目标空间必须可修改。
模拟实现strcat
char* my_strcat(const char* str1, const char* str2)
{
while (*str1) str1++;
while (*(char*)str1++ = *(char*)str2++) {
;
}
}
5.查找字符串函数的strstr
char * strstr ( const char *str2, const char * str1);
在str2中查找str1的字符串,如果找到了返回str2中这个字符串的首地址。如果找不到返回NULL。.0
char* my_strstr(const char* str1, const char* str2)
{
if (!*str2)//判断字符串是否为空
return (char*)str1;
char* ret1= (char*)str1;//将str类型转换
char *cp = ret1;
while (*ret1)
{
cp = ret1;
char* ret2 =(char*) str2;
while (*cp== *str2) {//遍历字符串
if (!*ret2)//判断str2是否到达‘0'的位置
return cp;
cp++, ret2++;
}
ret1++;//循环结束没有返回,从下一个字符开始查找
if (!*ret1)
return NULL;
}
return NULL;
}
二、内存函数
1.复制 memcpy,memmove
void * memcpy ( void * destination, const void * source, size_t num );
dest复制src中num
个字节
的数据。
模拟实现memcpy
void * my_memcpy ( void * dst, const void * src, size_t count)
{
void * ret = dst;
while (count--) {
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
return(ret);
}
·如果dst 和src指向同一个数组会发生什么?
int main()
{
int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 };
// 预期结果 1 2 1 2 3 4 7 8 9 0
my_memcpy(arr1+2, arr1, 16);
for (int i = 0; i < 10; i++)
{
printf("%d ", arr1[i]);
}
}
实际为 1 2 1 2 1 2 7 8 9 0
因为到5 6 的时候3 4被改成了1 2 ,5 6也就被改成1 2。
也就是说被复制的元素在复制前被改变了,导致复制结果失败。
如果是这样指向同一个数组呢?
int main()
{
int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 };
my_memcpy(arr1, arr1+2, 16);
for (int i = 0; i < 10; i++)
{
printf("%d ", arr1[i]);
}
}
复制结果没有问题。
对于这种情况,c语言有一个更强大的函数memmove
.
void * memmove( void * destination, const void * source, size_t num );
与memcpy的功能一样,但是memmove可以指向同一块空间。
模拟实现memmove
**void* my_memmove(void* dest, void* src, size_t num)
{
char* ret = dest;
//如果指向同一块空间 判断地址大小,避免数据在被复制前被改变
if ( (char*)dest-(char*)src< 0){
while (num)
{
*((char*)dest)++ = *((char*)src)++;
num--;
}
}
else {
while(num--){
*((char*)dest+num) = *((char*)src+num);
}
}
return ret;
}
2.比较 memcmp
int memcmp ( const void * ptr1, const void * ptr2, size_t num );
从ptr1和ptr2的位置开始比较num个字节,当两个字节数据不同时就会返回。
ptr1>ptr2 返回值>0;
ptr1=ptr2 返回值=0;
ptr1<ptr2 返回值<0;
来源::https://blog.csdn.net/qq_59078816/article/details/120402502


猜你喜欢
- 本文实例讲述了java数据结构排序算法之树形选择排序。分享给大家供大家参考,具体如下:这里我们就来说说选择类排序之一的排序:树形选择排序在简
- Git有很多可以配置的地方。比如,让Git显示颜色,会让命令输出看起来更醒目:$ git config --global color.ui
- 什么是MybatisMyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software fou
- 在VF、VB、PB的应用中,有些无法通过语言工具本身来完成的或者做得不理想的功能,我们会考虑通过Windows的API来完成。在那个年代,熟
- 目录环境准备1.数据库操作1.1获取所有数据库1.2获取指定库的所有集合名1.3.删除数据库2.文档操作2.1插入文档2.2查询文档2.3分
- 前面一篇文章我们介绍了使用CAS算法实现的非阻塞队列ConcurrentLinedQueue, 下面我们来介绍使用独占锁实现的阻塞队列Lin
- 最近IDEA打可执行Jar包搞了三天,一直失败,好好学习一下Maven-assembly,在此记录一下1. 需求项目打包,满足以下要求:1.
- @Value从Nacos配置中心获取值并自动刷新在使用Nacos作为配置中心时,除了@NacosValue可以做到自动刷新外,nacos-s
- 使用字符时,我们通常使用的是内置数据类型char。实例char ch = 'a';// Unicode for upperc
- 前言本文主要给大家介绍了关于Java中Unsafe类的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧1.Unsaf
- 用Java编写一个简单的酒店管理系统,供大家参考,具体内容如下为某个酒店编写程序:酒店管理系统,模拟订房、退房、打印所有房间状态等功能。1、
- 崩溃来源使用过AIDL进行跨进程通信的同学,肯定遇到过DeadObjectException这个崩溃,那么这个崩溃是怎么来的,我们又该如何解
- 本文实例讲述了Android编程基于重力传感器实现横竖屏放向切换功能。分享给大家供大家参考,具体如下:最近项目中用到了vr视频播放,因为自己
- 首先来看一下效果: 大体思路如下: 总体布局用了一个自定义的ViewGroup,里面包了两个View(top Vie
- 背景:本人不是Java开发人员,经过四年多的历练,可以说是一枚BI攻城师了吧,最近粗糙的写了一个Portal来集成cognos报表,下面就入
- redissonredisson 实现分布式锁的机制如下:依赖版本implementation 'org.redisson:redi
- Metro UI For JavaFX!这是一个Windows设计风格的UI库,使用非常简单,只要一行代码就可以实现整体UI风格的替换!ne
- 当我们在登录像QQ邮箱这种大多数的网站,往往在登录按键上会有下次自动登录这个选项,勾选后登录成功,在一段时间内,即便退出浏览器或者服务器重启
- 分部类(Partial Class)在C#2.0引入,分部方法(Partial Method)在C#3.0引入,这两个语法特性都具有相同的特
- 前言前面说到在我们应对高并发的场景,请求量过于大的情况下给我们服务器的压力很多,造成缓存穿透、击穿、雪崩,那么我们采用布隆过滤器,有兴趣的小