[转] memset用法
来源:互联网 发布:创维网络电视机顶盒 编辑:程序博客网 时间:2024/06/07 01:21
来自 csdn —— http://blog.csdn.net/liguanxing/article/details/5667008
以下的赋值方式是不正确的: memset(arr,2147483647,sizeof(arr)); 但是可以用一些技巧,来得到一个差不多的最大值,
比如像: memset(arr,0x7F,sizeof(arr));
它将arr中的值全部赋为2139062143 这是用memset对int赋值所能达到的最大值 如下demo是可以的,能把数组中的元素值都设置成字符1,
而,如下程序想吧数组中的元素值设置成1,却是不可行的#include <iostream>#include <string.h>using namespace std;int main(){char a[5];memset(a,'1',5);for(int i = 0;i < 5;i++)cout<<a[i]<<" ";system("pause");return 0; }
#include <iostream>#include <string.h>using namespace std;int main(){int a[5];memset(a,1,5);//这里改成memset(a,1,5 *sizeof(int))也是不可以的for(int i = 0;i < 5;i++)cout<<a[i]<<" ";system("pause");return 0;}
问题是:
1,第一个程序为什么可以,而第二个不行,
2,不想要用for,或是while循环来初始化int a[5];能做到吗?(有没有一个像memset()这样的函数初始化)
答:
1.因为第一个程序的数组a是字符型的,字符型占据内存大小是1Byte,而memset函数也是以字节为单位进行赋值的,所以你输出没有问题。而第二个程序a是整型的,使用memset还是按字节赋值,这样赋值完以后,每个数组元素的值实际上是0x01010101即十进制的16843009。你看看你输出结果是否这样?
2.如果用memset(a,1,20); 就是对a指向的内存的20个字节进行赋值,每个都用ASCII为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起就是1000000010000000100000001,就等于16843009,就完成了对一个INT元素的赋值了。 若赋值为-1,应该是memset(a,0xff ,sizeof(a)); 赋值为最大整数应该是memset(arr,0x7F,sizeof(arr));
0 0
- memset用法(转)
- memset用法详解(转)
- memset用法详解[转]
- [转] memset用法
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- memset用法详解(转)
- POJ 3012 : A Number from Yanghui Triangle - 快速幂;推公式
- ZOJ 1649 : Rescue - BFS
- ZOJ 2913 : Bus Pass - BFS
- 单行函数测试
- POJ 1465/ ZOJ 1136 : Multiple - BFS,余数判重
- [转] memset用法
- POJ 1523 / ZOJ 1119 - Tarjan算法
- POJ 1144 / ZOJ 1311 : Network - 割点个数
- 初学JQuery的DOM操作
- ZOJ 1586 : QS Network - prim算法解决最小生成树问题
- ZOJ 2588 : Burning Bridges - 无向图求割边(裸)
- POJ 1419 : Graph Coloring - 最大团(裸)
- POJ 2800 : Joseph\'s Problem (须仔细分析)
- POJ 2680 / ZOJ 2584 : Computer Transformation - 打表+找规律+高精度 / java大数