- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
静态存储与动态存储 我们知道使用变量前必须首先在变量说明部分对变量进行定义。变量一经定义,编译时系统就会给这些变量分配相应的内存空间。这种分配称为静态存储分配,各变量相应的内容空间在程序运行前就已经确定。 在实际应用中,经常遇到事先无法确定有多少数据要存储的情况,此时就不能用静态存储。为此,pascal引入了动态存储分配机制。 所谓动态存储分配是指事先不确定数据存储,在程序运行过程中根据实际需要动态申请所需存储空间,用完后及时将存储空间归还给系统。 指针类型 内存中的每一个存储单元都有一个编号,也就是“地址”。存储单元中存放的是各种类型的数据,也就是存储单元的“内容”。一个存储单元的“内容”的写入或读出,是根据存储单元的“地址”进行。 指针变量:其中存放的是某个存储单元的地址,即指针变量指向某个存储单元。 相对静态存储分配,动态存储分配有两个特点: ⑴可以在运行时根据需要随用随要; ⑵每次所申请的存储单元在内存中可以不连续,通过指针相互建立联系。 指针类型 Type 指针类型标示符=∧ 基类型标示符; Var 指针变量名:指针类型标示符; 这里的基类型可以是我们所学的除文件类型以外的任何数据类型 如: Type point=∧integer; Var p1,p2:point; 或:Var p1,p2:∧integer; Var p1,p2:∧integer; P1存放的是p1^的地址 P1^:=p2^,将指针变量P2指向的存储地址里的值赋值给指针变量P1指向的存储地址, p1,p2是不同址的。 P1:=p2,将指针变量P2的地址赋值给指针变量P1, p1,p2是同址的。 P1:=p2^是不成立的,因为二者是不同的数据类型。 注:此时只是说明了p1是一个指针变量,但这个存储单元一开始并不存在,即指针变量p1中没有具体的值。 动态变量的建立 new(指针变量名); 例:new(p1); 功能:开辟一个存储单元,此单元能存放的数据的类型正好是指针的基类型,并把此存储单元的地址赋给指针变量p1。 释放动态存储单元:dispose(指针变量名); 例: dispose (p1); 此时p1的值为nil 动态存储单元的引用 在给一个指针变量赋以某存储单元的地址后,就可以使用这个存储单元。 引用动态存储单元一般格式:<指针变量>^ 说明:①在用New过程给指针变量开辟了一个它所指向的存储单元后,要使用此存储单元的唯一方法是利用该指针。 ②对动态存储单元所能进行的操作是该类型(指针的基类型)所允许的全部操作。 例: 设有下列说明: var p:^integer; i:integer; 执行下列操作后的内存示意图: New(p); P^:=4;i:=p^; 假设有p1^、p2^两个变量 Program ch346; Type intptr=^integer; Var p1,p2:intptr; Begin new(p1); P1^:=5; P2:=p1; New(p1); p1^:=5; If p1=p2 then writeln(‘p1=p2’) else writeln(‘p1 p2’); If p1^=p2^ then writeln(‘p1^=p2^’) else writeln(‘p1^ p2^’) End. 输入两个整数,按从小到大的顺序输出 var p1,p2,t:^integer; begin new(p1);new(p2); readln(p1^,p2^); if p1^p2^ then begin t:=p1;p1:=p2;p2:=t; end; writeln(p1^,’ ‘,p2^); end. 链表结构 设有一批整数(12,56,45,86,77,……,),如何存放呢? 当然我们可以选择以前学过的数组类型。但是,在使用数组前必须确定数组元素的个数。如果把数组定义得大了,就会有大量空闲存储单元,定义得小了,又会在运行中发生下标越界的错误,这是静态存储分配的局限性。 动态存储分配结构――链表结构。 单链表 ①每个框表示链表的一个元素,称为结点。 ②每个结点包含两个域:一个域存放整数,称为数据域,另一个域存放下一个结点(称为该结点的后继结点,相应地,该结点为后继结点的前趋结点)的地址,称为指针域。 ③链表的第一个结点称为表头,最后一个结点表尾; ④指向表头的指针head称为头指针(当head为
您可能关注的文档
- 报销问题总汇.pptx
- 拉伸试验国家标准ppt.ppt
- 护理管理工具培训.ppt
- 拉格朗日差值.doc
- 拉拉山水电站竣工监理报告2014.8.doc
- 拉扎维模拟CMOS集成电路设计.ppt
- 拉深工序与磨具.ppt
- 拉长培训手册.doc
- 拉近心距离.pptx
- 拒绝烟和酒.ppt
- 化妆品公司动力部年度总结.pptx
- 七年级下册(2024)第六单元课外古诗诵读之《约客》课件(共26张PPT).pptx
- 24《寓言四则》优质课教学课件(共15张PPT).ppt
- 七年级下册(2024)第六单元课外古诗诵读之《竹里馆》课件(共26张PPT).pptx
- LIMS供应商概览与技术标书.pdf
- 线缆厂薪酬核算管理规章.doc
- 《课外古诗词诵读——逢入京使 》课件(共22张PPT)2025—2026学年统编版语文七年级下册.pptx
- 《课外古诗词诵读——贾生》课件(共22张PPT)2025—2026学年统编版语文七年级下册.pptx
- 7 谁是最可爱的人 课件 (共20张PPT) 2025-2026学年统编版语文七年级下册.pptx
- 电池厂叠片机配件管理规范规章.doc
原创力文档


文档评论(0)