C/C++的内存处理函数

1、memcpy

void * memcpy ( void * destination, const void * source, size_t num );

复制内存块

从source指向的位置直接复制num个字节的值到destination指向的内存块。

对于这个函数,source和destination指向的对象的底层类型是无关的;结果是数据的一个二进制复制。

这个函数不检查任何结束空字符(null)—— 它总是准确地复制num个字节。

为了避免溢出,source和destination两个参数指向的数组的大小应该至少是num字节,并且不应该重叠(对于重叠内存块, memmove 是一个更安全的方法))。

参数

destination        指向内容被复制到的目的数组的指针,类型被转换为void*。
source        指向复制数据的源数组的指针,类型被转换为void*。
num        要复制的字节数。

返回值

       返回目的指针destination。

Example:

/* memcpy example */
#include <stdio.h>
#include <string.h>

int main ()
{
  char str1[]="Sample string";
  char str2[40];
  char str3[40];
  memcpy (str2,str1,strlen(str1)+1);
  memcpy (str3,"copy successful",16);
  printf ("str1: %s\nstr2: %s\nstr3: %s\n",str1,str2,str3);
  return 0;
}

Output:

str1: Sample string
str2: Sample string
str3: copy successful

2、memmove

void * memmove ( void * destination, const void * source, size_t num );

移动内存块

从source指向的位置复制num个字节的值到destination指向的内存块。复制操作的发生就好像使用了中间缓存,允许destination和source重叠。

对于这个函数,source和destination指向的对象的底层类型是无关的;结果是数据的一个二进制复制。

这个函数不检查任何结束空字符(null)—— 它总是准确地复制num个字节。

为了避免溢出,source和destination两个参数指向的数组的大小应该至少是num字节。

参数

destination        指向内容被复制到的目的数组的指针,类型被转换为void*。
source        指向复制数据的源数组的指针,类型被转换为void*。
num        要复制的字节数。

返回值

       返回目的指针destination。

Example:

/* memmove example */
#include <stdio.h>
#include <string.h>

int main ()
{
  char str[] = "memmove can be very useful......";
  memmove (str+20,str+15,11);
  puts (str);
  return 0;
}

Output:

memmove can be very very useful.
3、memset

void * memset ( void * ptr, int value, size_t num );

填充内存块

将ptr指向的没存块的前num个字节设置为特定的值value(被解释为一个unsigned char类型的值)。

参数

ptr
       指向需要填充的内存块的指针。
value
       要设置的值,这个值是作为int型传递的,但是该函数用这个值的unsigned char类型转换值来填充内存块。
num        要是指特定值的字节数。

返回值

返回指针ptr。

Example:

/* memset example */
#include <stdio.h>
#include <string.h>

int main ()
{
  char str[] = "almost every programmer should know memset!";
  memset (str,'-',6);
  puts (str);
  return 0;
}

Output:

------ every programmer should know memset!

4、memchr

const void * memchr ( const void * ptr, int value, size_t num );
      void * memchr (       void * ptr, int value, size_t num );
在内存块中定位字符
在ptr指向的没存块的前num个字节中搜索value值得第一次出现(被解释为一个unsigned char类型的值),并返回指向该值的指针。

参数

ptr
       指向需要被执行搜索的内存块的指针。
value
       需要被定位的值。这个值是作为int型传递的,但是该函数用这个值的unsigned char类型转换值来进行逐位的搜索。
num        要是分析的字节数。

返回值

       返回指向ptr指向的内存块中value值第一次出现位置的指针。

       如果没有找到value值,则该函数返回NULL。

Example:

/* memchr example */
#include <stdio.h>
#include <string.h>

int main ()
{
  char * pch;
  char str[] = "Example string";
  pch = (char*) memchr (str, 'p', strlen(str));
  if (pch!=NULL)
    printf ("'p' found at position %d.\n", pch-str+1);
  else
    printf ("'p' not found.\n");
  return 0;
}

Output:

'p' found at position 5.
5、memcmp

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

比较两个内存块

将ptr2指向的内存块的签num个字节与ptr2指向的内存块的前num个字节进行比较,如果它们都相符合则返回0,反之则返回一个指示其中一个较大的非零值。

参数

ptr1        指向内存块的指针。 ptr2        指向内存块的指针 num        需要比较的字节数。

返回值

返回一个指示两个内存块的内容间的关系的整型值。

0值表示两个内存块的内容是相等的。

一个大于0的值表示,两个内存块中第一个不匹配的字节是ptr1的比ptr2的大,作为unsigned char类型比较的;小于0则表示相反。

Example:

/* memcmp example */
#include <stdio.h>
#include <string.h>

int main ()
{
  char str1[256];
  char str2[256];
  int n;
  printf ("Enter a sentence: "); gets(str1);
  printf ("Enter another sentence: "); gets(str2);
  n=memcmp ( str1, str2, 256 );
  if (n>0) printf ("'%s' is greater than '%s'.\n",str1,str2);
  else if (n<0) printf ("'%s' is less than '%s'.\n",str1,str2);
  else printf ("'%s' is the same as '%s'.\n",str1,str2);
  return 0;
}

Output:

Enter a sentence: building
Enter another sentence: book
'building' is greater than 'book'.
C/C++面试之算法系列--几个典型的内存拷贝及字符串函数实现 写一个函数,完成内存之间的拷贝。[考虑问题是否全面,是否考虑内存重叠问题] 返回void *支持链式操作,参数类型是void *以支持任意类型的指针,输入参数加上const修饰,最好加上assert对输入输出指针进行非NULL判断 void* memcpy( void *dest, const void *src, size_t count ) { char* pdest = static_cast( dest ); const char* psrc = static_cast( src ); // 依次从前拷贝,目的地址覆盖了源地址的数,此时从后往前拷贝 if( (pdest>psrc) && (pdest<(psrc+count))) //能考虑到这种情况就行了 { for( size_t i=count-1; i!=-1; --i ) pdest[i] = psrc[i]; } else { for( size_t i=0; i<count; ++i ) pdest[i] = psrc[i]; } return dest; } int main( void ) { char str[] = "0123456789"; memcpy( str+1, str+0, 9 ); cout << str << endl; memcpy( str, str+5, 5 ); cout << str << endl; system( "Pause" ); return 0; // 0012345678 // 4567845678 } strcmp(): Int simple_strcmp (const char *s1, const char *s2) { int ret; while ((ret = *(unsigned char *) s1 - *(unsigned char *) s2++) == 0 && *s1++); return ret; } memcmp(): int simple_memcmp (const char *s1, const char *s2, size_t n) { int ret = 0; while (n--&& (ret = *(unsigned char *) s1++ - *(unsigned char *) s2++) == 0); return ret; } strcmp只判断s1的‘/0’,没有长度的控制;memcmp有长度参数n的控制 memcpy(): char *simple_memcpy (char *dst, const char *src, size_t n) { char *ret = dst; while (n--) *dst++ = *src++; return ret; } 直接的内存之间的copy,不处理内存重叠的情况。 strcpy(): char *simple_strcpy (char *dst, const char *src) { char *ret = dst; while ((*dst++ = *src++) != '\0'); //相当简约,一句话即搞定 return ret; } 与memcpy区别就是对'\0'作为结束符 strncpy(): char *simple_strncpy (char *dst, const char *src, size_t n) { char *ret = dst; while (n--) { if ((*dst++ = *src++) == '\0') { while (n--) *dst++ = '\0'; return ret; } } return ret; } n和‘\0'都作为结束的控制符。如果n过大,则后面全补'\0'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值