一直误解的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);

  用法:#include

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

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

  返回指向dest的指针。

  memcpy

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

  用法:#include

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

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

posted on 2015-12-02 22:29  RunningSnail 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/tgycoder/p/5014386.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值