软件构造(5)- ADT抽象数据类型

抽象数据型与表示独立性:设计良好的抽象数据结构,通过封装来避免客户端获取数据的内部表示(即“表示泄露”),避免潜在的bug——在client和implementer之间建立“防火墙”

ADT的特性:表示泄漏、抽象函数AF、表示不变量RI

一.用户定义类型与数据抽象

数据抽象:由一组操作所刻画的数据类型

传统的类型定义:关注数据的具体表示 eg:用int类型来分别表示Date域中的日月年
抽象类型:强调“作用于数据上的操作”,程序员和client无需关心数据如何具体存储的,只需设计/使用操作即可。eg:直接用Date类型来表示具体日期

抽象类型是由操作定义的,与其内部操作无关
eg:当使用List类型时,不需关注其由linked list还是数组或是其他的数据结构实现的,只需知道List提供的方法:get() size() …
在这里插入图片描述

二.类型和操作的分类
  1. 数据类型:可变和不可变类型
    可变类型的对象:提供了可改变其内部数据的值的操作
    eg:Date可使用setMonth()方法改变其内部的值
    不变数据类型: 其操作不改变内部值,而是构造新的对象
    eg:String类型不可变
  2. 操作类型:
    1. creators 构造器:可以是构造函数或静态函数 eg:
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值