字符串拷贝和内存拷贝函数

简介: 字符串拷贝和内存拷贝函数

strcpy(拷贝字符串)  

定义函数:char *strcpy( char *dest, const char *src );

strcpy()函数只能拷贝字符串。strcpy()函数将源字符串src的每个字节拷贝到目的字符串dest中,src字符串末尾的'\0'也被拷贝过去。strcpy()函数返回参数dest的起始地址。如果参数dest所指的内存空间不够大,可能会造成缓冲溢出(buffer Overflow)的错误情况(程序员必须保证目标字符数组的空间足够容纳需要复制的字符串。如果src字符串比dest字符串长,多余的字符仍将被复制,它们将覆盖原先存储于dest数组后面的内存空间的值),在编写程序时请特别留意,或者用strncpy()来取代。如果参数src和dst在内存中出现重叠,其结果是未定义的。


strncpy(拷贝字符串)  

定义函数:char *strncpy( char *dest, const char *src, size_t n );

strncpy()会将参数src字符串拷贝前n个字符至参数dest所指的地址。函数返回参数dest的字符串起始地址。

注意n的取值范围,不要超过src和dest的长度。

#include<string.h>
#include<stdio.h>
int main()
{
    char a1[30]="string(1)";
    char b1[]="STRING(2)";
    printf("before strcpy()  : %s\n", a1 );
    printf("after  strcpy()  : %s\n", strcpy( a1, b1 ) );
    char a2[30]="string(1)";
    char b2[]="STRING(2)";
    printf("before strncpy() : %s\n", a2 );
    printf("after  strncpy() : %s\n", strncpy( a2, b2, 6 ) );
} 

memcpy(拷贝内存内容)  

定义函数:void * memcpy( void * dest, const void *src, size_t n );

memcpy()用来拷贝src所指的内存内容前n个字节到dest所指的内存地址上。与strcpy()不同的是,memcpy()会完整的复制n个字节,不会因为遇到字符串结束'\0'而结束。memcpy()函数可以拷贝任意类型的数据。memcpy()函数返回指向dest的指针。指针src和dest所指的内存区域不可重叠。在拷贝字符串时,通常都使用strcpy()函数;在拷贝其它数据(例如结构)时,通常都使用memcpy()函数。

memmove(拷贝内存内容)  

定义函数:void *memmove(void *dest, const void *src, size_t n );

memmove()与memcpy()一样都是用来拷贝src所指的内存内容前n个字节到dest所指的地址上。不同的是,当src和dest所指的内存区域重叠时,memmove()仍然可以正确的处理,不过执行效率上会比使用memcpy()略慢些。该函数返回指向dest的指针。

#include<string.h>
int main()
{
    char a[30]="string(1)";
    char b[]="string(2)";
    printf("before strcpy() :%s\n", a );
    printf("after strcpy() :%s\n", strcpy( a, b ) );
    a[30]="string(1)";
    b[]="string(2)";
    printf("before strncpy() : %s\n", a );
    printf("after strncpy() : %s\n", strncpy( a, b, 6 ) );
} 

memccpy(拷贝内存内容)  

定义函数:void * memccpy( void *dest, const void *src, int c, size_t n );

memccpy()用来拷贝src所指的内存内容前n个字节到dest所指的地址上。与memcpy()不同的是,memccpy()会在复制时检查参数c是否出现,若是则返回dest中值为c的下一个字节地址。该函数返回指向dest中值为c的下一个字节指针。返回值为NULL表示在src所指内存前n个字节中没有值为c的字节。  

#include<string.h>
#include<stdio.h>
int main()
{
    char a[]="string(a)";
    char b[]="string(b)";
    char *p;
    p = ( char * )memccpy( a, b, 'k', sizeof( b ) );
    if( p == NULL )
    {
        //注意p为NULL的情况,这时不能读取p所指的地方的内容 
        printf("the return pointer of mymccpy is null !\n");
    }
    else
    {
        printf("memccpy(): %s, *p = %c\n", a, *p );
    }
} 

bcopy(拷贝内存内容)  

定义函数:void bcopy ( const void *src,void *dest ,int n);

bcopy()与memcpy()一样都是用来拷贝src所指的内存内容前n个字节到dest所指的地址,不过参数src与dest在传给函数时是相反的位置。建议使用memcpy()取代 。


本文来自CSDN博客,转载请标明出处: http://blog.csdn.net/zhghost/archive/2010/02/03/5286308.aspx


相关文章
|
1月前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
34 3
|
12天前
|
缓存 算法 Java
本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制
在现代软件开发中,性能优化至关重要。本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制。通过调整垃圾回收器参数、优化堆大小与布局、使用对象池和缓存技术,开发者可显著提升应用性能和稳定性。
34 6
|
30天前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
1月前
|
存储 程序员 编译器
C语言——动态内存管理与内存操作函数
C语言——动态内存管理与内存操作函数
|
26天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
22 0
|
1月前
|
C语言 C++
c语言回顾-内存操作函数
c语言回顾-内存操作函数
40 0
|
1月前
|
存储 C语言 C++
来不及哀悼了,接下来上场的是C语言内存函数memcpy,memmove,memset,memcmp
本文详细介绍了C语言中的四个内存操作函数:memcpy用于无重叠复制,memmove处理重叠内存,memset用于填充特定值,memcmp用于内存区域比较。通过实例展示了它们的用法和注意事项。
66 0
|
1月前
一刻也没有为它哀悼~接下来登场的是动态内存分配的malloc与realloc以及free函数
一刻也没有为它哀悼~接下来登场的是动态内存分配的malloc与realloc以及free函数
69 0
|
3月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
378 0
|
25天前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
54 1