zoukankan      html  css  js  c++  java
  • C语言memset学习

    #include <stdio.h>
    #include <memory.h>
    void show(int a[][3]);   //函数声明
    void main(){
        
        int a[][3]={{23,46,11},{99,45,82},{72,90,21},{11,22,33}};//二维数组的定义
        show(a);                                     //二维数组作为形参,遍历显示
        memset(a,0,sizeof(a));//对二维数组填充 0操作;即清零
        show(a);    
    }
    void show(int a[][3])
    {   int i,j;
        for(i=0;i<4;i++){
            for(j=0;j<3;j++){
                printf("%d  ",a[i][j]);
            }
            printf("
    ");
        }
    }

    功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值,

      块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作

      用 法: void *memset(void *s, char ch, unsigned n);

      程序例:

      #include <string.h>

      #include <stdio.h>

      #include <memory.h>

      int main(void)

      {

      char buffer[] = "Hello world/n";

      printf("Buffer before memset: %s/n", buffer);

      memset(buffer, '*', strlen(buffer) );

      printf("Buffer after memset: %s/n", buffer);

      return 0;

      }

      输出结果:

      Buffer before memset: Hello world

      Buffer after memset: ***********

    一般来说,都是对数组进行修改操作,不要对cahr *s="i am student"操作,因为

    s指向的是一段只读的内存,而你memset又试图修改它,所以运行时要出错,修改办法char *s修改为char s[]

  • 相关阅读:
    BZOJ BLO 1123 (割点)【双连通】
    P4291 [HAOI2008]排名系统
    P3165 [CQOI2014]排序机械臂
    P3224 [HNOI2012]永无乡
    P1169 [ZJOI2007]棋盘制作
    P2303 [SDOi2012]Longge的问题
    P2216 [HAOI2007]理想的正方形
    P2473 [SCOI2008]奖励关
    P2617 Dynamic Rankings
    P2518 [HAOI2010]计数
  • 原文地址:https://www.cnblogs.com/shuqingstudy/p/4733064.html
Copyright © 2011-2022 走看看