数据结构_P9

原创 2016年06月01日 14:50:17
/*
	跨函数使用内存问题
	2016年6月1日14:35:27
*/
# include <stdio.h>
int f();

int main(void)
{
	int i = 10;
	i = f();
	printf("i = %d\n", i);

	return 0;
}

int f(void)      //现在的问题,当main()中调用完f()后,j还有没有??
        //回答:没有了。调用完函数内存就释放了。!!但是这只适用于静态变量
	 //如果是动态变量,还可以用,内存还在(需要自己选择是否释放)!!(见9_2)
{
	int j = 20;
	return j;
}


P9_2:

/*
	给int *p的p指针变量通过函数调用外部赋值
	要想跨函数使用内存,只能通过动态内存分配来解决
	2016年6月1日14:38:11
*/
# include <stdio.h>    
# include <malloc.h>
void fun(int **q);

int main(void)
{
	int *p;   //现在要想p指针变量指向一个变量地址,即赋值,通过调用fun()函数实现。
	fun(&p);   //此函数结束后,p变量指向的变量仍然还在,并没有被释放,因为是动态内存!

	return 0;
}
/*fun()函数申请的动态内存,被函数main调用后,这块内存并没有被释放,仍然可以使用*/
void fun(int **q)     //指针的指针
{
	*q = (int *)malloc(4);    //动态申请4字节内存,首地址赋值给p变量,则p指向int类型数据。并且函数调用完p还在,没被释放
}



版权声明:本文为博主原创文章,转载请注明出处:http://blog.csdn.net/pop_rain

数据结构作业p60

  • 2012年09月18日 14:50
  • 2KB
  • 下载

数据结构与计算机原理2003p1-6.rar

  • 2008年12月19日 20:25
  • 499KB
  • 下载

数据结构第四版(P47~50)

#include #include #include typedef int ElemType; typedef struct DNode { ElemType data; struct DNod...

算法与数据结构(9-11章)

  • 2012年01月10日 12:27
  • 393KB
  • 下载

《数据结构》交换双向循环链表的结点p和它的前驱结点

2.9 交换双向循环链表的结点p和它的前驱结点   题目描述: 已知p指向双向循环链表中的一个结点,其结点结构为data,prior,next三个域; 写出算法change(p),交换p所指向的...

数据结构与算法分析 c++ P75 Vector 实现

按书中的方式,实现一下简单的Vector ,加深理解。 #pragma once #include template class Vector { public : explicit Vec...

《数据结构》--严蔚敏 静态链表排序 p270

《数据结构》--严蔚敏 静态链表排序

数据结构教程(P40~45)

#include #include #include typedef int ElemType; typedef struct LNode { ElemType data; struc...

(数据结构)栈_迷宫求解(严蔚敏P50) _模仿

一般方法: #include"ds.h" #define MAX_COLUM 10 //迷宫最大列数 #define MAX_ROW 10 //迷宫最大行数 #define MAX_NUM 10...

《数据结构》严蔚敏.吴伟民P63-65.循环队列

///dabbysunshine@qq.com /** 《数据结构》严蔚敏.吴伟民P63-65.循环队列 **/ ///如有BUG,请发邮件联系 #include "stdio....
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据结构_P9
举报原因:
原因补充:

(最多只允许输入30个字)