C語言中mem系列的記憶體操作函式
阿新 • • 發佈:2020-12-28
首先說明一些mem系列的函式針對記憶體進行操作,操作的基本單位是位元組,與型別無關。標頭檔案均為<string.h>
1.memcpy
void * memcpy ( void * destination, const void * source, size_t num );
從source位置向後複製num個位元組資料到destination的記憶體位置中。
2.memmove
void * memmove ( void * destination, const void * source, size_t num );
與memcpy函式功能和用法相同;都可以處理source記憶體塊和destination記憶體塊重疊的問題。
附上memmove庫函式實現的程式碼;`
#include<stdio.h>
#include<Windows.h>
#include<assert.h>
void* my_memmove(void* dst, const void* src,size_t num)
{
void* ret = dst;
if (src >= dst || (char*)src + num < (char*)dst) {
while (num--) {
*(char*)dst = *(char*)src;
dst =(char*)dst+ 1;
src =(char*)src+1;
}
}
else {
while (num--) {
*((char*)dst + num) = *((char*)src + num);
dst = (char*)dst - 1;
src = (char*)src - 1;
}
}
return ret;
}
int main()
{
char str1[] = "fbs.adaasdaee.";
char* str2 = str1 + 3;
printf("%s\n", my_memmove(str1, str2, 5));
return 0;
}
執行結果:
3.memset
void * memset ( void * ptr, int value, size_t num );
將ptr指標指向的num個位元組設定為指定值;一般常用於一段資料的初始化。
4.memcmp
int memcmp ( const void * ptr1, const void * ptr2, size_t num );
與strcmp()類似,只不過這個函式逐個比較的記憶體中的位元組對應的ASCII碼,前者大則返回大於0的整數(有的編譯器返回1,有的返回兩者ASCII碼的差值),等於則返回0,小於則返回小於0的整數。
該庫函式實現:
#include<stdio.h>
#include<Windows.h>
#include<assert.h>
int my_strcmp1(const char* str1, const char* str2)
{
assert(str1);
assert(str2);
while (*str1 == *str2) {
if (*str1 == '\0') {
return 0;
}
str1++, str2++;
}
if (*str1 > * str2) {
return 1;
}
return -1;
}
int my_strcmp2(const char* str1, const char* str2)
{
assert(str1);
assert(str2);
int ret = (*str1 - *str2);
while (!ret&& *str1) {
ret = (*str1 - *str2);
++str1, ++str2;
}
return ret;
}
int main()
{
char str1[] = "baasdaee";
char str2[] = "badsdaefff";
printf("%d\n", my_strcmp1(str1, str2));
printf("%d\n", my_strcmp2(str1, str2));
return 0;
}