• 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;
    }
    /* 输出:

    */ 

  • 相关阅读:
    windows11系统如何设置锁屏壁纸
    postgresql 数据库索引创建
    jzo3059 雕塑
    C++项目实战-实际应用
    组件化系列~代码分支管理
    el-tree实现表格方式菜单
    基于FPGA设计的低成本四通道 1GSPS 示波器设计资料
    盘一盘这个没资格出现在面试环节的场景题。
    数据库单字段存储多个标签(位移操作)
    [leetcode] 946. 验证栈序列
  • 原文地址:https://blog.csdn.net/weixin_40186813/article/details/125463505