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

  • 相关阅读:
    leetcode--Remove Duplicates from Sorted Array
    leetcode--Valid Parentheses
    leetcode--Longest Substring Without Repeating Characters
    leetcode--Combination Sum
    leetcode--Valid Sudoku
    java 4对象群体的组织
    java 3 接口与多态&输入输出流
    java 3类的继承
    java 2类与对象[学堂在线]
    计算机网络{网页开发与服务配置}
  • 原文地址:https://www.cnblogs.com/shuqingstudy/p/4733064.html
Copyright © 2011-2022 走看看