memset函数用法及注意事项

头文件
#include<cstring>

------------------------------------------

在memset使用时要千万小心,在给char 以外 的数组赋值时,
     只能初始化为0或者-1。    (看最后的0和1的补码)
///////////      给bool类型数组可以初始化1
------------------------------------------

头文件#include<cstring>
int arr[100];
memset(arr,0,sizeof(int)*100);
arr是数组的首地址,0就是要将这些地址的内容赋值为0,sizeof(int)求出int类型的长度,
乘以100就表示arr数组的整个长度。

也可以这样  ------
     memset(arr,0,sizeof(arr));

------------------------------------------

memset函数用法及注意事项memset 函数是内存赋值函数,用来给某一块内存空间进行赋值的。
其原型是:void* memset(void *_Dst, int _Val, size_t _Size);
使用时在文件头加上#include "stdlib.h" 。
_Dst是目标起始地址,_Val是要赋的值,_Size是要赋值的字节数 。

例1:

char str[9];
       我们用memset给str初始化为“00000000”,用法如下
       memset(str,0,8);
注意,memset是逐字节 拷贝的。
下面再看一个例子:
    例2:
      int num[8];
       我们用memset给str初始化为{1,1,1,1,1,1,1,1},

memset(num,1,8);//这样是不对的

一个int是4个字节的,8个int是32个字节,所以首先要赋值的长度就不应该为8而是32。
     因为memset是 逐字节 拷贝,以num为首地址的8字节空间都被赋值为1,
     即一个int变为0X00000001 00000001 00000001 00000001,
    显然,把这个数化为十进制不会等于1的。

所以,在memset使用时要千万小心,在给char以外的数组赋值时,
     只能初始化为0或者-1。    (看最后的0和-1的补码)

因为在计算机里,0的二进制都是0,-1的二进制都是1。

最近才发现memset的这个问题,之所以要写这篇文章,是因为我在自己的DES算法里多处用到了memset,而我当时却不知memset有这个问题,特此记下,引以为鉴。

---------------------
例如:

#include "stdio.h"
#include <string.h> 
int main()

   char s[100]="Golden Global View";
   memset(s,‘G‘,6); 
   printf("%s",s);  
   getchar(); 
   return 0; 
}

结果

----------
GGGGGG Global View
----------

----------------------------------------------------------------------
补码+0和-0相同?

我知道+0和-0补码相同,可是比如在八位机上,
+0(00000000)求补码是10000000,
而-0(10000000)求补码是(00000000)啊,
求补码的做法是符号位不变,其余为取反,然后再加1,
没错吧,那我的错误出在哪里?

----------
提问者采纳

就没有正确的地方,在计算机中是不存在正负零之分的.
而你对补码理解又有错误的.补码只不过是用来表示带符号数而已.
补码的原则是:
   正数的补码是其本身,也就是原码.
   负数的补码是各位取反后加1.也就是其反码加1.
   +0的补码就是其原码,也就是说是0000 0000而已(对于8位来说)
   -0的补码是其反码加1,其反码是1111 1111,
   当然,其反码加1后就是溢出一个进位后,仍然是0000 0000.

----------------------------------------------------------------------

--------------------------------------------------------------------------------
请问-1的二进制如何表示?

不知道是1000000000000001    还是1111111111111111
我觉得是第一个,首位代表符号,0代表正、1代表负,剩下的代表实际数值,
为什么在C语言里第二个是-1呢

--------------------
提问者采纳

第一个是原码的话,
表示的也是-1第二个是补码表示的-1,
补码即原码除符号位外,全部取反+1
1000000000000001取反后是1111111111111110,再+1即1111111111111111 
C里面数是以补码方式来储存的

--------------------------------------------------------------------------------

memset函数用法及注意事项

时间: 2024-10-06 15:50:44

memset函数用法及注意事项的相关文章

fscanf函数用法及注意事项

/*FSCANF.C:This program writes formatted data to afile.It then uses fscanf to read the various databackfromthefile.*/ #include <stdio.h> FILE *stream; int main(void) { long l; float fp; char s[81]; char c; stream=fopen("fscanf.out","w

PB SetFilter() 函数用法及注意事项

函数作用:为DataWindow或者DataStore指定数据过滤规则.通常在调用该函数前使用函数Retrieve将数据检索到客户端,该函数可以决定检索到客户端的这些数据哪些可以显示,哪些不能显示.该函数对客户端的数据进行操作,和后台数据库没有任何关系.在设置完过滤规则后使用函数Retrieve检索数据是不合理的,每次设置过滤规则后都检索数据,这样的执行效率很低.需要注意的是,该函数紧紧是设置过滤规则,并不进行过滤.函数Filter是进行过滤的,使用最近设置好的过滤规则对数据进行过滤.函数语法:

memcpy,memmove,memset函数福彩3D平台搭建用法及实现

一.函数介绍:福彩3D平台搭建论坛:haozbbs.com Q14465950671.memcpy函数原型:extern void memcpy(void dest, const void *src, size_t count);用法:#include<string.h>功能:由src所指内存区域复制count个字节到dest所指内存区域.说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针.注意:和strcpy相比,memcpy不是遇到'/0'就结束,而是一定会拷贝完n个字

C语言 memset函数及其用法

定义 void *memset(void *s, int c, unsigned long n); 描述 将指针变量 s 所指向的前 n 字节的内存单元用一个“整数” c 替换,注意 c 是 int 型.s 是 void* 型的指针变量,所以它可以为任何类型的数据进行初始化. 例子 # include <stdio.h> # include <string.h> int main(void) { int i; //循环变量 char str[10]; char *p = str;

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];

thinkphp中I(&quot;parm&quot;)用法的注意事项

php中用来传输的方式有两种$_GET 和 $_POST, thinkphp 提供了一种兼容两中传输方式的做法I(“param”) 但是请注意:在使用php中的函数时需要传入参数时不能用I(“parm”),必须使用采用的传输方式$_GET 或 $_POST传入,否则出错 thinkphp中I("parm")用法的注意事项,布布扣,bubuko.com

memset函数

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

memest函数用法说明(转自Lee.Kevin)

memest原型 (please type "man memset" in your shell)   void *memset(void *s,  int c, size_t n); memset:作用是在一段内存块中填充某个给定的值,它对较大的结构体或数组进行清零操作的一种最快方法. 常见的三种错误 第一: 搞反了c 和 n的位置. 一定要记住 如果要把一个char a[20]清零, 一定是 memset(a, 0, 20) 而不是 memset(a, 20,  0) 第二: 过度

一直误解的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(array