首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >为什么推荐序列作为常规接口?

为什么推荐序列作为常规接口?
EN

Software Engineering用户
提问于 2015-05-25 06:23:41
回答 1查看 561关注 0票数 3

在参考伯克利的文本版本时,我们提到:

将程序表示为序列操作有助于我们设计模块化的程序。也就是说,我们的设计是通过组合相对独立的部分来构建的,每个部分都转换了一个序列。通常,我们可以通过提供一个标准组件库和一个以灵活方式连接组件的常规接口来鼓励模块化设计。

例如,在python中,<class 'list'><class 'tuple'>是主要用于存储的顺序数据模型的一些类型。

例如,在python中,<class 'dict'>是一种流行的非顺序数据模型。

Text reference给出了下面用python编写的两个不同问题的解决方案,并提到了类似的解决方案,这是不令人信服的,因为这两个问题不能作为做出这一决定的典型示例。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> def sum_even_fibs(n):
        """Sum the even members of the first n Fibonacci numbers."""
        return sum(filter(iseven, map(fib, range(1, n+1))))
>>> sum_even_fibs(20)
3382
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
>>> def acronym(name):
        """Return a tuple of the letters that form the acronym for name."""
        return tuple(map(first, filter(iscap, name.split())))
>>> acronym('University of California Berkeley Undergraduate Graphics Group')
('U', 'C', 'B', 'U', 'G', 'G')

尽管给出了这些例子,但我仍然不清楚做出“序列作为常规接口”的决定。

因此,在设计库或组件时,为什么推荐选择顺序类型数据模型作为常规接口?这是否与这些顺序数据模型(由python/python/lisp提供)的闭包属性有关?

注:麻省理工学院出版社的SICP文本中也有同样的建议。

EN

回答 1

Software Engineering用户

发布于 2015-05-25 07:10:38

字典的目的是返回给定一个指定键的值,而不是作为顺序容器。仅仅因为其他数据结构是顺序的,但字典并不意味着序列的好处是无效的。

序列是计算中的三种基本逻辑结构之一。每一个(可解的)计算问题都可以通过三个工具来解决:序列、循环和决策。

序列保留元素之间的关系;也就是说,第一个元素必须发生在第二个元素之前,而第二个元素必须发生在第三个元素之前,依此类推。这意味着我们可以在一个序列中检索下一个元素,并确保相对于其他元素,我们以正确的顺序检索了元素。这显然是有益的:每次读取单词时,它们总是由相同的字母序列组成,方法由每次调用它们时相同的指令序列组成。

你可以让序列变懒。您可以创建一个实现状态机的类,并在每次调用方法时从状态机返回一个元素。你可以缓存序列。

序列可以从链接列表、树和其他数据结构中创建。每种数据结构都有其特定的特性;单链接列表可以在一个方向上有效地遍历,但不能在另一个方向上遍历。一些数据结构,如二叉树,将为您提供顺序访问和有效的随机访问。一些数据结构,如双链接列表,允许您有效地向后遍历序列。

如果您编写数据结构以符合顺序接口,则可以将序列的实现切换到最适合给定需求的数据结构。然后,您可以根据该接口编写代码,并确保底层实现是模块化的。

我对python中的序列不太了解,但是Scheme中的基本数据结构(在最初的SICP中使用)是一个列表,您可以以何种方式组成这样的列表(本质上是序列),以及提供的灵活性和能力应该是显而易见的。每一种包含序列的语言都允许这样的组合。

票数 7
EN
页面原文内容由Software Engineering提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://softwareengineering.stackexchange.com/questions/284912

复制
相关文章
Remove China Apps凉了?作死的阿三们并没有罢休
近日,一款名为『Remove China Apps』的应用,在印度火了,上架2周,下载量500W+,日均下载量超过20W,登上了Google PlayStore印度地区排行榜榜首,而TikTok(抖音国际版)仅位居第4。这款应用的功能,已经写得很明目张胆了——卸载中国应用。
Android扫地僧
2020/06/09
6020
正常的工作流程
修改文件,将它们更新的内容添加到索引中。 $ git add file1 file2 file3 你现在为commit做好了准备,你可以使用git diff命令再加上–cached参数,看看哪些文件将被提交(commit)。 (如果没有–cached参数,git diff会显示当前你所有已做的但没有加入到索引里的修改。)你也可以使用git status命令来获得当前项目的一个状况。
用户3004328
2018/09/06
7450
如何从Google Play下载Android应用的APK安装文件?
有时候可能因为种种原因,你无法直接在手机上连接Google Play来下载应用(比如说你设备不兼容,说你所在地区不支持,或者你想装到上不去Google Play的Kinlde上),但你又想安装这个应用,怎么办呢?
Enjoy233
2019/03/05
8.7K0
如何从Google Play下载Android应用的APK安装文件?
Anbox安装apk失败(提示Failure res=-113等)的解决方法
详细描述,如下(Anbox:如何安装Google Play商店并启用ARM(libhoudini)支持,简单方法):
zhangrelay
2019/01/31
8.4K0
Anbox安装apk失败(提示Failure res=-113等)的解决方法
uniapp下载apk并且安装(uniapp打包后apk白屏)
-alias xxx : xxx是别名 xxx.keystore : 文件名
全栈程序员站长
2022/08/01
6.5K0
uniapp下载apk并且安装(uniapp打包后apk白屏)
Apache编译后无法正常工作
因为某个场景的需求,要在一个国产系统Rocky4.2(国产凝思4.2操作系统)上安装Apache,虽说此系统是基于Redhat 5.8开发的,但是发现yum安装源包管理,RPM命令倒是能用,但是底层依赖完全没有,这就尴尬了,so,只能源码编译安装了。
后场技术
2020/09/03
2.8K0
网页离开时改变标题“崩溃欺骗”
我们先创建一个 js 文件,我们用记事本就好了,然后改个文件名,不妨就叫crash-cheat.js吧,你们可以随意! 然后把文件放到 source 文件夹的 js 文件夹的 src 里面。(我用的 next 主题,放这里统一存放,其他主题随意)
Cell
2022/02/25
1.2K0
缩小APK,增加下载量
原文地址:Shrinking APKs, growing installs: How your app’s APK size impacts install conversion rates 原文作者
Android 开发者
2018/05/31
2.9K0
iPhone Safari 下载企业包出现 apk
有人反馈企业包下载链接,使用 iPhone Safari 打开后出现下载 apk 的提示
莫空9081
2021/11/24
1.2K0
如何在程序崩溃时自动生成 stacktrace
有什么好的办法可以在 C/C++ 程序段错误退出时输出堆栈信息,来方便查找错误么?
ClearSeve
2022/02/10
1K0
pycharm调试教程_程序调试时应当用
在了解Python编程之前,我们需要先弄明白如何编写运行代码。所以非常有必要先讲解一下Python的集成开发环境,也就是IDE(Integrated Development Environment)。PyCharm是一款优秀的开源Python语言集成开发工具。PyCharm能够调试运行程序,另外它还提供了强大的代码提示功能。在PyCharm的下载页面能够指定安装系统选择付费版(Professional)或者免费版(Community)进行安装。付费版的PyCharm提供了更强大的Python服务器后端开发功能。这里我们以windows系统免费版(PyCharm Community)下载安装。我们只对PyCharm的基本功能进行简单概括,详细内容请查阅官方文档。PyCharm下载地址(https://www.jetbrains.com/PyCharm/download/#section=windows)
全栈程序员站长
2022/09/25
1.3K0
pycharm调试教程_程序调试时应当用
5分钟短文 | Android证书生成,签名,验证,虽然难,但学一次就够了!
从Android演进开始,APK签名就已经成为Android的一部分,并且android要求所有Apks都必须先签名,然后才能将其安装在设备上。关于如何生成密钥以及如何签名的文章很多。一个Apk,但我们将从安全角度进行研究。在对Apk文件进行反编译或反向工程之后,应查看哪个文件,以获取有关最初对应用进行签名的开发人员的更多信息。
程序员小助手
2020/06/17
1.1K0
直接下载google play应用-APK Downloader
作者:matrix 被围观: 4,603 次 发布时间:2013-11-08 分类:兼容并蓄 | 2 条评论 »
HHTjim 部落格
2022/09/26
4.8K0
直接下载google play应用-APK Downloader
如何在.NET程序崩溃时自动创建Dump?
首先能明确的一点是"程序崩溃退出了是不能用常规的方式 dump 的",因为整个进程树都已经退出。现场已经无法使用常规的方式读取到。
InCerry
2022/11/14
1.8K0
apk加壳加密工具(apk protect) v1.0下载「建议收藏」
apk加壳加密工具(apk_protect)是用于加密apk文件中dex文件的加密工具,加密的东西主要有字符串加密、流程加密、类名加密和api加密(未完成,后续支持)等,有于较好的保护apk文件,使之不易激活成功教程分析。__我对apk_protect在线加密的有效性进行了测试和分析,发现确实给android_apk提供了无法激活成功教程的加密壳。虽然在线加密已经是非常省时省力的了,但是仍然有不少程序员懒于折腾(尽管这已经不叫折腾了,就是上传一下再下载,比起写代码来说,这简直就是享受)。于是,意外的发现他们已经推出了懒人版apk_protect。没错,懒人版!也就是免安装单机版!无ads无插件无需安装,简单选定apk文件点击加密即可!_____使用方法___运行apkcrypt.exe,选择你所需要加密的apk,然后点击“add_apk_protect”。
全栈程序员站长
2022/09/14
1.7K0
win7怎么查看驱动是否正常工作
我们在使用电脑的时候经常会遇到各种各样的问题,今天我就教大家在电脑使用过程中出现问题时怎么检查电脑驱动是否正常齐全。
点云PCL博主
2019/07/30
2.5K0
VC调试时输出调试信息到Debug窗口
TRACE宏(afx.h, AfxTrace) (TRACE将信息输出到afxDump对象,只在_DEBUG定义时输出,最多输出512个字符,格式化与printf类似) afxDump对象(afx.h, CDumpContext) (afxDump调用OutputDebugString把信息输出到Debug窗口,继承CObject的类可以重载Dump方法格式化此类的Dump信息,输出时把afxDump作为Dump方法的参数) OutputDebugString(windows.h) (TRACE, afxDump在使用MFC时使用,不使用MFC时可以用OutputDebugString,AfxOutputDebugString和OutputDebugString用法一样)
战神伽罗
2019/07/24
1.7K0
点击加载更多

相似问题

从playstore下载时签名的apk崩溃

12

获取崩溃签名的apk /bundle,但正常调试apk工作正常

115

下载apk时从google playstore获取邮件id

20

从playstore下载时应用程序崩溃

00

如何在playstore ApK上安装调试APK

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文