数据结构_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

结构化数据、半结构化数据和非结构化数据

结构化数据、半结构化数据和非结构化数据结构化数据结构化的数据是指可以使用关系型数据库表示和存储,表现为二维形式的数据。一般特点是:数据以行为单位,一行数据表示一个实体的信息,每一行数据的属性是相同的。...
  • liangyihuai
  • liangyihuai
  • 2017年02月04日 18:23
  • 6558

数据结构--树(tree)的简单介绍

定义树的一种自然的方式是递归。一般的树:    一棵树是N个节点和N-1条边的集合。 树叶(leaf):没有儿子的节点。 兄弟(siblings):具有相同父亲的节点。用类似的方法可以定义祖父(gra...
  • tanga842428
  • tanga842428
  • 2016年09月05日 15:32
  • 1188

结构化数据(structured),半结构化数据(semi-structured),非结构化数据(unstructured)

研究一下分布式架构的实现方式   结构化数据(structured),半结构化数据(semi-structured),非结构化数据(unstructured)   ...
  • haiross
  • haiross
  • 2014年03月11日 17:09
  • 6625

程序员代码面试指南 IT名企算法与数据结构题目最优解 ,左程云著 ,P513.pdf

  • 2018年01月15日 11:32
  • 80.91MB
  • 下载

数据结构作业p60

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

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

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

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

///dabbysunshine@qq.com /** 《数据结构》严蔚敏.吴伟民P63-65.循环队列 **/ ///如有BUG,请发邮件联系 #include "stdio....
  • SunshineDabby
  • SunshineDabby
  • 2011年03月11日 12:55
  • 4606

洛谷[P3616] 富金森林公园【数据结构】【线段树】【树状数组】

Description博艾的富金森林公园里有一个长长的富金山脉,山脉是由一块块巨石并列构成的,编号从1到N。每一个巨石有一个海拔高度。而这个山脉又在一个盆地中,盆地里可能会积水,积水也有一个海拔高度,...
  • FYOIER
  • FYOIER
  • 2017年08月02日 22:16
  • 202

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

一般方法: #include"ds.h" #define MAX_COLUM 10 //迷宫最大列数 #define MAX_ROW 10 //迷宫最大行数 #define MAX_NUM 10...
  • u013080459
  • u013080459
  • 2014年01月12日 11:32
  • 1255

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

链表实现Stack stack.h  #pragma once #include #include struct Node; typedef struct Node *PtrToN...
  • vellerzheng
  • vellerzheng
  • 2017年05月16日 10:12
  • 107
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据结构_P10
举报原因:
原因补充:

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