一直误解的memset函数

1、“想当然”导致的后果

今天犯了一个十分低级的错误,在对一个整型数组用memset进行初始化设置所有元素值为1.可是结果却大出所料,很意外啊!接着,我就做了代码测试。

#include <iostream>

using namespace std;

int array1[10001];
int array2[10];
int array3[10];

int main()
{
    memset(array1, -1, 10);
    memset(array2, 0, 10);
    memset(array3, 1, 10);

    for (int i = 0; i < 10; i++)
        cout << array1[i] << ‘ ‘;
    cout << endl;
    for (int i = 0; i < 10; i++)
        cout << array2[i] << ‘ ‘;
    cout << endl;
    for (int i = 0; i < 10; i++)
        cout << array3[i] << ‘ ‘;
    cout << endl;

    return 0;
}

输出结果如下:

这是啥情况呢?

2、知其然,而不知其所以然

带着这个疑问去查了相关资料,才明白自己真的是犯了一个很low的错误啊!只知道,memset函数可以对数据进行初始化,但是不知其中的原理。这也是学习中的大忌啊!

下面给出对memset的解释及应用。

函数原型:extern void* memset(void *buffer,int c,int count),buffer是指针或者数组名,c是赋给buffer的值,count是buffer的长度。

该函数在socket中多用于清空数组.如:原型是memset(buffer, 0, sizeof(buffer)),另外memset 用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’;

例如:char a[100];memset(a, ‘/0‘, sizeof(a));

memset可以方便的清空一个结构类型的变量或数组。

struct Student
{
char csName[16];
int iSeq;
int iType;
};

对于变量 Student stu;一般情况下清空stu的方法:

stu.csName[0]=‘/0‘; stu.iSeq=0; stu.iType=0;

用memset就非常方便:
memset(&stTest,0,sizeof(struct sample_struct));

如果是数组:struct sample_struct TEST[10];则

memset(TEST,0,sizeof(struct sample_struct)*10);

扩展一下,介绍一下strcpy和memcpy。

strcpy

  原型:extern char *strcpy(char *dest,char *src);

  用法:#i nclude

  功能:把src所指由NULL结束的字符串复制到dest所指的数组中。

  说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。

  返回指向dest的指针。

  memcpy

  原型:extern void *memcpy(void *dest, void *src, unsigned int count);

  用法:#i nclude

  功能:由src所指内存区域复制count个字节到dest所指内存区域。

  说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针。

时间: 2024-10-12 09:47:56

一直误解的memset函数的相关文章

memset()函数

1. memset()函数原型是extern void *memset(void *buffer, int c, int count)        buffer:为指针或是数组, c:是赋给buffer的值, count:是buffer的长度. 这个函数在socket中多用于清空数组.如:原型是memset(buffer, 0, sizeof(buffer)) Memset 用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为' '或'/0': 例:char a[100];

strcpy, memcpy, memset函数

一. strcpy函数 原型声明:char *strcpy(char* dest, const char *src); 头文件:#include <string.h> 和 #include <stdio.h> 功能:把从src地址开始且含有NULL结束符的字符串复制到以dest开始的地址空间 说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串. 返回指向dest的指针. 实现代码: char * strcpy(char * strDest,c

透彻分析C/C++中memset函数

原文:http://blog.csdn.net/dan15188387481/article/details/49621447 在C语言中,经常需要对内存进行操作,里面涉及很多函数,但是memset函数的使用有一点需要大家格外注意,这也是我在做项目时遇到过的一个问题,调试了很久才找出来错误. 函数原型是:void *memset(void *s, int ch, size_t n); 函数功能是:将s所指向的某一块内存中的前n个字节的内容全部设置为ch指定的ASCII值, 第一个值为指定的内存地

strcpy,memcpy,memset函数实现

strcpy 实现,只能拷贝字符串 char* strcpy(char* des,const char* source) { char* r=des; assert((des != NULL) && (source != NULL)); while((*des++ = *source++)!='\0'); return r; } memcpy 实现,注意目的地址和源地址重合的情况,以及强制类型转换 void *myMemCopy(void *dest,const void *src,siz

memset函数

常见错误: 第一: 搞反了 ch 和 n 的位置. 一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20);而不是 memset(a,20,0); 第二: 过度使用memset,我想这些程序员可能有某种心理阴影,他们惧怕未经初始化的内存,所以他们会写出这样的代码: 这里的memset是多余的. 因为这块内存马上就被全部覆盖,清零没有意义. 另:以下情况并不多余,因某些编译器分配空间时,内存中默认值并不为0: 第三: 其实这个错误严格来讲不能算用错memset,但是它

memset函数具体说明

1.void *memset(void *s,int c,size_t n)总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c. 2.样例#include void main(){char *s="Golden Global View"; clrscr(); memset(s,'G',6);printf("%s",s); getchar();return 0;} 3.memset() 函数经常使用于内存空间初始化.如:char str[100];mems

C语言中的memset函数和数组指针

代码: 1 #include <iostream> 2 #include <cstring> 3 4 using namespace std; 5 6 int main(){ 7 int a[5] = {1}; 8 memset(a,5,sizeof(a)); 9 cout<<a[0]<<" "<<a[1]<<endl; 10 cout<<a<<" "<<a+

pow log memset函数

1.计算一个数是几位数: 可以用log10(N)+1:这个函数,其重载形式是 double   res: int  N: res=log10((double)N)+1:应该注意数据都是double类型的. 2.memset 函数: 这个函数赋值的时候是按字节来赋值的,例如 Int   arr[110][110]; memset(arr,1,sizeof(int)):这样数组是不能赋值为   1   的,因为按字节赋值,而在VC中int 类型的数据占四个字节,这样赋值就变成了 二进制   0000

C/C++中memset函数

本文学习参考http://baike.baidu.com/link?url=ZmSyY8ciB_nJt9KM-W2fiEFJrC2mugFsLqRdY2b4pLe8rD_jRXyN7_pj0GBBD2bKyt6Xm-lpUlAO97H94dUYXa 1.memset函数的声明和含义如下: 函数解释:将s所指向的某一块内存中的前n个字节的内容全部设置为 ch 指定的 ASCII值, 第一个值为指定的内存地址,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作, 其返回值为指向s的指针