”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 抽象:一种程序化的思维方式

抽象:一种程序化的思维方式

发布于2024-11-08
浏览:119

Abstractions: A Way of Thinking Programmatically

“为什么程序员拒绝起床?他们陷入了太多的抽象层!”

在编程中,就像在生活中一样,我们经常需要简化复杂的事情以使它们更易于管理。想象一下,试图向从未见过计算机的人解释互联网,您不会从谈论服务器和协议开始。相反,你可以使用类比、故事或简化版本来传达这个想法。这就是编程中抽象的意义所在:简化复杂的事情。

抽象:简单的秘诀
把编程想象成烹饪。当您遵循食谱时,您不会考虑烤箱中发生的化学反应;您会考虑烤箱中发生的化学反应。只要按照步骤做就可以做出一道美味的菜肴。编程中的抽象是类似的 - 它允许您专注于您想要实现的目标,而不必担心幕后的复杂细节。

什么是抽象?
抽象是管理编程复杂性的一种方法。它涉及创建复杂系统的简化模型,使您能够专注于高级操作而不是复杂的细节。通过抽象代码的某些部分,您可以更有效地工作、重用代码并减少出错的机会。

三明治隐喻:构建抽象层
让我们深入研究一个使用三明治比喻的实际例子。
1.成分(低级细节) 在最基本的层面上,你有成分:面包、生菜、番茄、奶酪和火鸡。这些就像编程中的原始数据或低级操作。它们很重要,但直接处理它们可能很麻烦。

例子:

let bread = "whole grain";
let lettuce = "romaine";
let tomato = "sliced";
let cheese = "cheddar";
let turkey = "smoked";

2.三明治(更高层次的抽象) 您无需单独处理每种成分,而是创建一个三明治。这是一个抽象概念,将各种成分捆绑在一起形成一个更易于管理的实体。

例子:

function makeSandwich(bread, lettuce, tomato, cheese, turkey) {
    return `${bread} sandwich with ${lettuce}, ${tomato}, ${cheese}, and ${turkey}`;
}
let myLunch = makeSandwich("whole grain", "romaine", "sliced", "cheddar", "smoked");

通过将细节抽象到 makeSandwich 函数中,您不必每次想要做午餐时都担心各个成分 - 您只需调用该函数即可。

3.午餐订单(甚至更高的抽象) 现在,如果您想在熟食店订购午餐怎么办?你甚至不需要考虑三明治的制作过程;您只需下订单即可。这是更高层次的抽象,您可以与更简化的界面进行交互。

例子:

function orderLunch(type) {
    if (type === "sandwich") {
        return makeSandwich("whole grain", "romaine", "sliced", "cheddar", "smoked");
    }
    // Other lunch options could go here
}
let myOrder = orderLunch("sandwich");

实际用例场景:构建用户界面
在构建复杂系统(例如用户界面(UI))时,抽象至关重要。假设您正在为社交媒体应用程序构建 UI。您无需为每个按钮、文本框和图像单独编写代码,而是创建代表它们的抽象组件。

function createButton(label) {
    return ``;
}
function createUserProfile(name, bio) {
    return `
        

${name}

${bio}

${createButton("Follow")}
`; } let profile = createUserProfile("Koobimdi", "Passionate about coding and storytelling.");

这里,createButton函数抽象了按钮的创建,createUserProfile函数抽象了用户配置文件。您并不是每次都处理原始 HTML 标签 - 只是更高级别的抽象。

需要注意的要点
抽象简化了复杂性:它允许您在更高的细节级别上工作,而无需担心底层的复杂性。
抽象层:您创建的抽象层越多,您就越能专注于每个级别的重要内容。
可重用性: 抽象允许您创建可在多个上下文中使用的通用函数或组件,从而鼓励可重用性。
效率:通过抽象重复性任务,您可以编写更高效且可维护的代码。

结论
抽象就像一个食谱,可以简化烹饪过程,让您可以制作复杂的菜肴,而不必陷入细节。在编程中,它是一个强大的工具,可以帮助您管理复杂性、更高效地工作并编写更简洁的代码。

“记住,当事情变得太复杂时,是时候抽象出解决办法了——就像厨房太乱时你点外卖一样!”

版本声明 本文转载于:https://dev.to/koobimdi/abstractions-a-way-of-thinking-programmatically-3cdc?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何克服PHP的功能重新定义限制?
    如何克服PHP的功能重新定义限制?
    克服PHP的函数重新定义限制在PHP中,多次定义一个相同名称的函数是一个no-no。尝试这样做,如提供的代码段所示,将导致可怕的“不能重新列出”错误。 但是,PHP工具腰带中有一个隐藏的宝石:runkit扩展。它使您能够灵活地重新定义函数。 runkit_function_renction_re...
    编程 发布于2025-03-10
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。让我们考虑以下查询: select data d.data_ti...
    编程 发布于2025-03-10
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符在postgresql中提取最后一行,您可能需要遇到与数据集合中每个不同标识的信息相关的信息。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: id dat...
    编程 发布于2025-03-10
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-03-10
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    To resolve this issue, we employ a clever CSS solution that solves the problem:position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%)...
    编程 发布于2025-03-10
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-03-10
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-03-10
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-03-10
  • 为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    为什么使用固定定位时,为什么具有100%网格板柱的网格超越身体?
    网格超过身体,用100%grid-template-columns 为什么在grid-template-colms中具有100%的显示器,当位置设置为设置的位置时,grid-template-colly修复了?问题: 考虑以下CSS和html: class =“ snippet-code”> g...
    编程 发布于2025-03-10
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-03-10
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-03-10
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-03-10
  • 如何限制动态大小的父元素中元素的滚动范围?
    如何限制动态大小的父元素中元素的滚动范围?
    在交互式接口中实现垂直滚动元素的CSS高度限制,控制元素的滚动行为对于确保用户体验和可访问性是必不可少的。一种这样的方案涉及限制动态大小的父元素中元素的滚动范围。问题:考虑一个布局,其中我们具有与用户垂直滚动一起移动的可滚动地图div,同时与固定的固定sidebar保持一致。但是,地图的滚动无限期...
    编程 发布于2025-03-10
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-03-10

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3