引言:
在C语言中,按照取值的不同,数据类型可以分为两类:

  • 原子类型:
    是不可以再分解的基本类型,包括整型、实型、字符型等。
  • 结构类型:由若干个类型组合而成,是可以再分解的。例如,整型数组是由若干整型数据组成的。
    比如,在C语言中变量声明int a,b,这就意味着,在给变量a和b赋值时不能超出int的取值范围,变量a和b之间的运算只能是int类型所允许的运算。

因为不同的计算机有不同的硬件系统,这就要求程序语言最终通过编译器或解释器转换成底层语言,如汇编语言甚至是通过机器语言的数据类型来实现的。可事实上,高级语言的编程者不管最终程序运行在什么计算机上,他的目的就是为了实现两个整型数字的运算,如a+b、a-b、a×b和a/b等,他才不关心整数在计算机内部是如何表示的,也不想知道CPU为了实现1+2进行几次开关操作,这些操作是如何实现的,对高级语言开发者来讲根本不重要。于是我们就会考虑,无论什么计算机、什么计算机语言,大都会面临着如整数运算、实数运算、字符运算等操作,我们可以考虑把它们都抽象出来。

抽象是指抽取出事物具有的普遍性的本质。它是抽出问题的特征而忽略非本质的细节,是对具体事物的一个概括。抽象是一种思考问题的方式,它隐藏了繁杂的细节,只保留实现目标所必需的信息。

定义:
我们对已有的数据类型进行抽象,就有了抽象数据类型。

抽象数据类型(Abstract Data Type,ADT):是指一个数学模型及定义在该模型上的一组操作。抽象数据类型的定义仅取决于它的一组逻辑特性,而与其在计算机内部如何表示和实现无关。

比如,各个计算机,不管是大型机、小型机、PC、平板电脑、PDA,甚至智能手机都拥有“整数”类型,也需要整数间的运算,那么整型其实就是一个抽象数据类型,尽管它在上面提到的这些在不同计算机中实现方法上可能不一样,但由于其定义的数学特性相同,在计算机编程者看来,它们都是相同的。因此,“抽象”的意义在于数据类型的数学抽象特性。

而且,抽象数据类型不仅仅指那些已经定义并实现的数据类型,还可以是计算机编程者在设计软件程序时自己定义的数据类型,比如我们编写关于计算机绘图或者地图类的软件系统,经常都会用到坐标。也就是说,总是有成对出现的x和y,在3D系统中还有z出现,既然这三个整型数字是始终在一起出现,我们就定义一个叫point的抽象数据类型,它有x、y、z三个整型变量,这样我们很方便地操作一个point数据变量就能知道这一点的坐标了。

事实上,抽象数据类型体现了程序设计中问题分解、抽象和信息隐藏的特性。抽象数据类型把实际生活中的问题分解为多个规模小且容易处理的问题,然后建立一个计算机能处理的数据模型,并把每个功能模块的实现细节作为一个独立的单元,从而使具体实现过程隐藏起来。

为了便于对抽象数据类型进行规范的描述,给出了描述抽象数据类型的标准格式:

ADT 抽象数据类型名
Data数据元素之间逻辑关系的定义
Operation操作1初始条件操作结果描述操作2......操作n......
endADT

数据结构之抽象数据类型相关推荐

  1. 【Python数据结构】 抽象数据类型 Python类机制和异常

    这篇是<数据结构与算法Python语言描述>的笔记,但是大头在Python类机制和面向对象编程的说明上面.我也不知道该放什么分类了..总之之前也没怎么认真接触过基于类而不是独立函数的Pyt ...

  2. 数据结构之抽象数据类型(C语言实现)

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.概念 二.定义格式 三.具体实现 总结 前言 数据类型是一组性质相同的值的集合以及定义于这个值集合上的一组操作的总 ...

  3. 数据结构、数据类型、抽象数据类型之间的区别

    三者的定义(蓝字可忽略): 数据结构:是相互之间存在一种或多种特定关系的数据元素的集合,包括逻辑结构和物理结构.(数据元素是最基本的数据单位,最基本的数据元素是一个二进制位.) 逻辑结构指反映数据元素 ...

  4. 复数抽象数据类型C语言,采用C/C++语言如何实现复数抽象数据类型Complex

    记录一下! 采用C/C++语言如何实现复数抽象数据类型Complex #include typedef struct Complex { double e1; // 实部 double e2; // ...

  5. 数据结构第一次作业——抽象数据类型

    1.作业内容(1分) ADT Rational{ 数据对象:D={e1,e2|e1,e2都是Elemtype类型} 数据关系:R={<e1,e2>} 基本操作:Builtration(&a ...

  6. 数据结构简介以及抽象数据类型的实现

    数据结构简介 数据结构(英语:data structure)是计算机中存储.组织数据的方式. 数据结构意味着接口或封装:一个数据结构可被视为两个函数之间的接口,或者是由数据类型联合组成的存储内容的访问 ...

  7. 数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型的概念

    数据: 是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称.如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形.图像.声音.动画等通过特殊编码定义后的数 ...

  8. c语言 数据结构 list、queue、tree抽象数据类型的定义与实现 详尽代码和注释

    本文使用c语言定义并实现list.queue.tree抽象数据类型,代码有详尽注释,可以通过代码熟悉原理并运用数据结构. 0.ADT基础知识 类型包括两类信息,属性和操作.在编程时,根据编程问题匹配合 ...

  9. 数据结构的基本概念和抽象数据类型

    1.基本概念和术语 数据:是对客观事物的符号表示. 数据元素:数据的基本单位,一个数据元素可由若干个数据项组成,数据项是数据的不可分割的最小单位 数据对象:性质相同的数据元素的集合是数据的一个子集 数 ...

最新文章

  1. WPF实用指南二:移除窗体的图标
  2. python画横条形图-用matplotlib画条形图(bar)
  3. GDCM:gdcm::ImageWriter的测试程序
  4. 21/100. Two Sum
  5. SQL Server 索引结构及其使用(三)(转)
  6. mysql yog中文版下载_SQLyog 12
  7. cookie 以及session 的使用
  8. 百度网盘资源搜索网站大全
  9. xml--通过DOM解析XML
  10. 教务管理系统乱码服务器不可,青果教务管理系统Post登录(二)
  11. 如何在word左侧显示目录
  12. 双高教育建设与混合制校企合作
  13. stc12c5a单片机c语言adc,stc12c5a60s2单片机用自带ADC采集电压源程序
  14. linux服务器端口使用drcom拨号联网
  15. Python爬虫教程:爬取王者荣耀全套皮肤【附源码】
  16. 2017-2018-1 20155228 《信息安全系统设计基础》第一周学习总结
  17. 你的名字烂大街了吗?数据揭开国人起名背后的秘密……
  18. StringWriter介绍
  19. html手机分辨率选择,[HTML5]手机屏幕分辨率和浏览器分辨率
  20. java hashtable 数据结构_java数据结构——哈希表(HashTable)

热门文章

  1. Git And Github
  2. 新玺配资:央行降准 房地产板块春天来了
  3. java uuid 长度处理
  4. highside 介绍
  5. PyQt(Python+Qt)学习随笔:QListWidget删除项的takeItem方法
  6. Vue CLI 3 安装、创建、配置、安装插件
  7. Python 学习系列(4) 在Python中建立N维数组并赋初值
  8. 金牌汉马首推人脸识别直播,Sioeye开启马拉松新时代
  9. SHA1算法代码实现
  10. 苹果iOS 15.5正式版实用小功能盘点 这11个功能你要知道