数据结构_P10

原创 2016年06月01日 16:17:28
/*
*  !要用结构体时,最高效方式就是定义时直接定义为结构体指针,然后用的时候用外部函数临时创建并赋值,用后再释放就好,这样在不使用此结构体时占内存少(4字节)
*  跨函数使用内存问题:给结构体指针通过外部函数整体创建赋值
*  总结:结构体高效使用方式(结构体指针,动态内存分配):定义结构体指针,需要用的时候临时通过外部函数对指针赋值,为防止函数调用完内存释放,外部函数中通过申请动态内存存放指针,返回的指针赋值给之前定义的结构体,实现结构体赋值
*  2016年6月1日14:50:37
*/
# include <stdio.h>
# include <malloc.h>

struct Student * CreatStudent();
void ShowStudent(struct Student *);

struct Student
{
	int sid;
	int sage;
};

int main(void)
{
//	struct Student st;   //已经分配了内存空间,占8字节,但是这样比较耗内存啦,我可以用的时候现分配,用完就释放,这样比较好,所以需要用指针定义,用的时候在调用函数现场创建赋值就可以了!!
	struct Student *ps;    //现在只有一个结构体类型的4字节指针变量,然而还没有赋值,指针变量还没有指向,现在要通过外部函数给此指针赋值,因为用到了外部跨函数使用内存,则必须使用动态内存分配malloc函数!
	ps = CreatStudent();    //外部函数创建结构体,通过指针地址整体赋值
	ShowStudent(ps);
	return 0;
}

struct Student * CreatStudent()
{
	struct Student * ps = (struct Student *)malloc(sizeof(struct Student));  //!必须要用malloc动态内存分配,否则函数调用完内存释放,无法实现创建赋值
	ps->sid = 99;
	ps->sage =88;
	return ps;
}

void ShowStudent(struct Student *pst)
{
	printf("%d %d\n", pst->sid, pst->sage);
}

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

相关文章推荐

数据结构作业p60

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

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

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

王道数据结构课后习题 | P37

3、设L为带头节点的单链表,编写算法实现从尾到头反向输出每个节点的值。 我想到的是reverse一下/笑哭 想想这个就有点杀鸡用牛刀的感觉… 看了题解说是可以用递归…卧槽瞬间orzclass S...

数据结构学习 65页 P2

实现代码: main.cpp #include #include "stack.h" #include using namespace std; int main() { Stack...

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

///dabbysunshine@qq.com /** 《数据结构》严蔚敏.吴伟民P63-65.循环队列 **/ ///如有BUG,请发邮件联系 #include "stdio....

数据结构与算法分析 P86 Stack 栈的实现

链表实现Stack stack.h  #pragma once #include #include struct Node; typedef struct Node *PtrToN...

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

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

算法之链表练习(数据结构之算法分析:C语言描述 P62 3.3)

/*给你一个链表L和另一个链表P,它们包含以升序排列的整数。操作PrintLots(L,P) 将打印L中那些由P所指定位置上的元素。*/ #include #include struct...

王道数据结构课后习题 | P018

3.长度为L的顺序表,编写一个时间复杂度为O(n),空间复杂度为O(1)的算法,该算法删除线性表中所有值为x的元素。 一看就是典型的双指针问题,于是我写代码如下for(i=0,j=i+1;j...

数据结构习题与解析P82【例3-2-8】Java实现

package maintest; import java.util.Stack; import myutil.MyUtil; /** * @ClassName: StackTest ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据结构_P10
举报原因:
原因补充:

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