my_memcpy可以处理不重叠的内存拷贝(只能从前向后拷贝)
#include<stdio.h>
#including<string.h>
#include<assert.h>
void* my_memcpy (void* dest,const void* src,size_t num)
{
void* ret=dest;
assert(dest!=NULL);
assert(srt!=NULL);
while(num--)
{
*(char*)dest=*(char*)src;
++(cahr*)des;
++(char*)src;
}
return 0;
}
int main()
{
int arr1[]={1,2,3,4,5};
int arr2[]={0};
my_memcpy(arr2,arr1,sizeof(arr1));
return 0;
}
my_memmove可以处理重叠的内存拷贝(可以从前向后也可以从后向前拷贝)
#include<stdio.h>
#include<string.h>
# include<assert.h>
viod* my_memmvoe(void* dest,const void* src,size_ count)
{
cahr* ret=dest;
assert(dest!=NULL);
assert(src!=NULL);
if(dest<src)
{
while(count--)
{
*(char*)dest=*(char*)src;
++(char*)dset;
++(char*)src;
}
}
else
{
while
{
*((char*)dest+count)=*((char*)src+count);
}
}
return ret;
}
int main()
{
int arr[]={1,2,3,4,5,6,7,8,,9,10};
my_memmove(arr+2,arr,20);
return 0;
}
my_offsetof
#include<stdio.h>
struct S
{
char c1;
int a;
char c2;
};
#define MY_OFFSETOF(struct_name,member_name) (int)&(((stryct_name*)0)->member_name)
int main()
{
printf("%d\n",MY_OFFSETOF(struct S,c1));
printf("%d\n",MY_OFFSETOF(struct S,a));
printf("%d\n",MY_OFFSETOF(struct S,c2));
return 0;
}