• C和指针 第11章 动态内存分配 11.4 使用动态分配的内存


    11.4 使用动态分配的内存
        用malloc分配一块内存:
        int *pi;
        ...
        pi = malloc( 100 );
        if( pi == NULL ){
            printf( "Out of memory!\n" );
            exit( 1 );
        } 
        符号NULL定义于stdio.h,它实际上是字面值常量0。它在这里起着视觉提醒器的作用,提醒我们进行测试的值是一个指针而不是整数。
        如果内存分配成功,那么我们就拥有了一个指向100字节的指针。在整型为4字节的机器上,这块内存将被当做25个整型元素的数组,因为pi是一个指向整型的指针。
        提示:
        如果你的目标就是获得足够存储25个整数的内存,这里有一个更好的技巧来实现这个目的。
        pi = malloc( 25 * sizeof(int) );
        这个方法更好一些,因为它是可移植的。即使是在整形长度不同的机器上,它也能够获得正确的结果。
        既然已经有了一个指针,那么该如何使用这块内存呢?当然可以使用间接访问和指针运算来访问数组的不同整数位置,下面这个循环就是这样做的。它把这个新分配的数组的每个元素都初始化为0:
        int *pi2, i;
        ...
        pi2 = pi;
        for( i = 0; i < 25; i += 1 ){
            *pi2++ = 0;
        } 
        可以看到,不仅可以使用指针,也可以使用下标。下面的循环所执行的任务和前面一个相同:
        int i;
        ...
        for( i = 0; i < 25; i += 1 ){
            pi[i] = 0;
        } 

    /*
    ** 使用动态分配的内存。 
    */
    #include <stdio.h>
    #include <stdlib.h>

    int main( void ){
        int *pi;
        int *pi2;
        int i;
        
        /*
        ** this technique is not portable to store 25 ints.
        */
        pi = (int *)malloc( 100 );
        if( pi == NULL ){
            printf( "Out of memory!\n" );
            exit( EXIT_FAILURE );
        } 
        /*
        ** free dynamic memory.
        */
        free( pi );
        /*
        ** this technique is portable to store 25 ints.
        */
        pi = (int *)malloc( 25 * sizeof(int) );
        if( pi == NULL ){
            printf( "Out of memory!\n" );
            exit( EXIT_FAILURE );
        } 
        printf( "print original elements in memory pointed to by pi:\n" );
        int counter = 0;
        for( i = 0; i < 25; ++i ){
            printf( "%d ", pi[i] );
            counter++;
            if( counter % 5 == 0 ){
                printf( "\n" );
                counter = 0;
            }
        }
        printf( "\n" );
        /*...*/
        pi2 = pi;
        for( i = 0; i < 25; i += 1 ){
            *pi2++ = 0;
        } 
        printf( "after set elements to zero by using *pointer++:\n" );
        printf( "print original elements in memory pointed to by pi:\n" );
        counter = 0;
        for( i = 0; i < 25; ++i ){
            printf( "%d ", pi[i] );
            counter++;
            if( counter % 5 == 0 ){
                printf( "\n" );
                counter = 0;
            }
        }
        printf( "\n" );
        /*...*/
        for( i = 0; i < 25; i += 1 ){
            pi[i] = 1;
        }     
        printf( "after set elements to one by using pointer[subscript]:\n" );
        printf( "print original elements in memory pointed to by pi:\n" );
        counter = 0;
        for( i = 0; i < 25; ++i ){
            printf( "%d ", pi[i] );
            counter++;
            if( counter % 5 == 0 ){
                printf( "\n" );
                counter = 0;
            }
        }
        printf( "\n" );
        /*
        ** free dynamic memory.
        */
        free( pi );
        
        return EXIT_SUCCESS;
    }
    /* 输出:

    */ 

  • 相关阅读:
    2023-09-07 monetdb-mvc的实现与并发控制-思考
    Java 第1天:环境搭建
    【Java SE】封装,面向对象三大特性之一
    zookeeper 理论合集
    2022/10/1——基于stm32mp157a的M4核LED灯实验
    Mem Reduct 内存自动清理工具
    Selenium+Pytest自动化测试框架实战
    博客停更,已开公众号-《GIS杂谈》,之后会在公众号持续更新相关知识,敬请关注,欢迎讨论~
    (已导出) hyperv中的ubuntu虚拟机双网卡设置
    2核2G3M带宽服务器腾讯云和阿里云价格、性能对比
  • 原文地址:https://blog.csdn.net/weixin_40186813/article/details/125463505