文档章节

动态内存分配的传递

follitude
 follitude
发布于 2016/05/16 11:09
字数 581
阅读 51
收藏 2

#include <stdio.h>
#include <stdlib.h>
//Three methods to return the memory area allocated by malloc

第一种方法:
返回所分配内存的首地址,将首地址强制转换为int或long保存。在以后调用中,将该数值转换为所需类型对应的指针类型
int alloc_mem_1(int num)
{
    int *q;

    q = (int *) malloc(num);
    return (int) q;
}

第二种方法:
类似于第一种方法,只是将内存首地址转换为int或long保存在指针中。以后调用传递变量时,可以将一个int或long变量取址传递即可。

void alloc_mem_2(int *p, int num)
{
    int *q;

    q = (int *) malloc(num);
    *p = (int) q;
}

第三种方法:
使用指向指针的指针保存分配存储内存的首地址。

void alloc_mem_3(int **p, int num)
{
    *p = (int *) malloc(num);
}


int main(void)
{
    int i;
    int handle;

    /*three pointers to test three methods*/
    int *p1 = NULL;
    int *p2 = NULL;
    int *p3 = NULL;

    /*test of alloc_mem_1()*/
    printf("1: test of alloc_mem_1()\n");
    handle = alloc_mem_1(10 * sizeof(int));
    p1 = (int *)handle;
    for (i = 0; i < 10; i++){
        *(p1 + i) = i ;
        printf("%d\t", p1[i]);
    }

    printf("\n");
    free(p1);

    /*test of alloc_mem_2()*/
    printf("2: test of alloc_mem_2()\n");
    alloc_mem_2(&handle, 10 * sizeof(int));
    p2 = (int *)handle;
    for (i = 0; i < 10; i++){
        p2[i] = i * 2;
        printf("%d\t", p2[i]);
    }

    printf("\n");
    free(p2);

    /*test of alloc_mem_3()*/
    printf("3: test of alloc_mem_3()\n");
    alloc_mem_3(&p3, 10 * sizeof(int));
    for (i = 0; i < 10; i++){
        p3[i] = i * 3;
        printf("%d\t", p3[i]);
    }

    printf("\n");
    free(p3); 

    return 0;
}


其中:
1.第一种方法是采用返回值的方式,将所分配的内存的首地址以整型之返回。在调用该函数时,将其返回值强制转换为相应类型的指针即可,上例中是转换为整型指针。然后就可以以该内存为首地址,进行读写num个整形数据;
2.第二种方法的实现类似于第一种,只是将所分配内存的首地址存在一个整型指针里面;
3.第三种方法是使用指向指针的指针来实现动态内存的传递。这个方法在《高质量C/C++编程》中最后的一份试题中提到了这种方法。

以上三种方法中,第三种方法应该是常用的,也是容易理解的。前两种方法一般应用在一些特别的方面,譬如,GUI编程中窗口的handle的使用,等等。

本文转载自:http://blog.chinaunix.net/uid-21736802-id-1817763.html

共有 人打赏支持
follitude
粉丝 5
博文 118
码字总数 4956
作品 0
浦东
C++中std::allocator的使用

标准库中包含一个名为allocator的类,允许我们将分配和初始化分离。使用allocator通常会提供更好的性能和更灵活的内存管理能力。 new有一些灵活性上的局限,其中一方面表现在它将内存分配和对...

fengbingchun
2017/12/31
0
0
JavaSE学习笔记系列:面向对象(1)

接下来一段时间,会持续发布一个JavaSE学习笔记系列文章! 1.面向对象的思想 要考虑问题有哪些类和哪些对象。 要考虑这些类和这些对象有哪些行为和属性。 考虑类和类之间具备了哪些关系。(继...

landy8530
2017/12/15
0
0
关注C++细节——浅谈指针使用中注意事项

相信大家对指针的用法已经很熟了,这里也不多说些定义性的东西了,只说一下指针使用中的注意事项吧。 一.在定义指针的时候注意连续声明多个指针时容易犯的错误,例如int * a,b;这种声明是声明...

iaccepted
2011/09/02
0
0
C语言中内存分布及程序运行中的BSS段、数据段、代码段、堆和栈

1. 栈(stack):又称堆栈,栈是由编译器自动分配释放,存放函数的参数值,局部变量的值等(但不包括static声明的变量,static意味着在数据段中存放变量)。除此之外,在函数被调用时,栈用来...

china_lx1
06/27
0
0
lwip内存分配详解对比 mem_init memp_init 源码分析

Lwip内存分配 mem_init ()分配方式介绍 内存堆的初始化函数,主要是告知内存堆的起止地址,以及初始化空闲列表,memmalloc( ) 申请分配内存。将总共需要的字节数作为参数传递给该函数,返回值...

cicue
2014/06/04
0
0

没有更多内容

加载失败,请刷新页面

加载更多

smart-doc特殊功能使用介绍

smart-doc从8月份底开始开源发布到目前为止已经迭代了几个版本。在这里非常感谢那些敢于用smart-doc去做尝试并积极提出建议的社区用户。因此决定在本博客中重要说明下smart-doc的功能,包括使...

上官胡闹
昨天
0
0
JavaEE——Junit

声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。 Junit Junit又名单元测试,Junit是用来测试Jav...

凯哥学堂
昨天
0
0
读《美丽新世界》

一、背景 十一国庆节从重庆回深圳的时候,做得绿皮车,路上看了两本书:李笑来的《韭菜的自我修养》和禁书《美丽新世界》。 上篇文章已经分享了 读《韭菜的自我修养》,这篇文章来记录一下《...

tiankonguse
昨天
0
0
archlinux下基于Jenkins,docker实现自动化部署(持续交互)

本文永久更新地址:https://my.oschina.net/bysu/blog/2250954 【若要到岸,请摇船:开源中国 不最醉不龟归】 -----------------------------------第一部分Jenkins的安装与使用-----------...

不最醉不龟归
昨天
0
0
Spark Parquet file split

在实际使用 spark + parquet 的时候, 遇到了两个不解的地方: 我们只有一个 parquet 文件(小于 hdfs block size), 但是 spark 在某个 stage 生成了4个 tasks 来处理. 4个 tasks 中只有一个 ta...

Aaaaaaaron
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部