伪代码

Apr 18, 2025 am 10:33 AM

伪代码:提升代码效率的秘密武器

最近,Yonatan Doron在Medium上发表了一篇题为“代码的艺术——为什么你应该编写更多伪代码”的文章。作为伪代码的爱好者,我非常喜欢这个标题。伪代码是指描述你想要做什么或想要沟通的内容的“代码”,但它不属于任何特定的语言,也不使用任何正确的API或其他内容。

编写带注释的伪代码有助于整理思路、提升动力并提前规划预期的代码结果。这样,当我们开始编写代码时,我们总会有这份思维导图或框架来帮助我们集中注意力并提高效率。

Jeremy Keith曾将其比作编写剧本:

“当用户提交表单时,显示带有确认信息的模态对话框。”然后他鼓励大家编写一个剧本……但我指的不是JavaScript意义上的剧本;而是指编剧或戏剧意义上的剧本。逐行写下你想要完成的每个步骤。完成后,将你用英语(或葡萄牙语)编写的每一行剧本翻译成JavaScript。

我看到教育工作者一次又一次地使用这种技术。但这不仅仅是供教师使用和学生学习的——它对任何人都大有裨益。我发现自己在编写真实代码之前会先编写伪代码,当然,有时我也会将其保留在代码注释中。最常见的是,我将其用于Notion文档或Slack对话中,以表达我的观点。

即使是简单的想法:

<code>如果 env.dev
  停止邮件投递</code>

任何具有逻辑和分支或分步操作的内容都将从中受益匪浅。请注意,这段代码不是有效的代码。在我能想到的任何语言中,它都不是有效的。有时,我会出于肌肉记忆而随意添加一些括号或分号。谁在乎呢?这只是为了与自己或他人沟通想法。

<code>如果(支持网格)
  使用网格
否则
  使用flexbox将内容布局在基本行中</code>

这是很自然的。他们很可能也不会在意语法,他们只会理解其中的意思。

<code>在表单提交时
  验证
  如果存在错误
     显示错误;
  否则
     提交到api;
     如果api成功
        显示ui成功;
     否则
        显示ui失败;</code>

(写完这些之后,让我想起了uilang。看看那里的纯文本代码块是如何工作的。)

Yonatan的文章缺少真实的伪代码示例,所以我四处询问。看看这些很棒的例子!

我的整个笔记本都是伪代码……

这些在开始编码之前会转换成注释,这样我就能知道我在做什么以及之后做了什么图片。twitter.com/9vfJYfweDh

— Ruth John (@Rumyra) 2019年5月28日

白板非常适合编写伪代码以及添加图形。图片。twitter.com/56FUu4rhmU

— norom (@_norom_) 2019年5月28日

哦,我以前经常这样做……图片。twitter.com/lQi4Y8RhwP

— Ben Koppenens (@bkoppenens) 2019年5月28日

一直都在用!图片。twitter.com/YFVVNwls5M

— Bryan (@iamBryanSanders) 2019年5月28日

尝试同时使用JavaScript和php有时会有点棘手图片。twitter.com/Xp0bQyV86D

— frankie | webdev (@azoicx) 2019年5月29日

迟来的加入。快速脚本映射。图片。twitter.com/n1kYDxKgya

— Adam Styles (@thelibstyles) 2019年5月31日

我很惊讶有多少伪代码是用纸写的!这真的很酷。对我来说有点奇怪,因为我很少用纸来做任何事情。我可能应该这样做。

Pseudo Code

以上是伪代码的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1601
29
PHP教程
1503
276
显示:内联,显示:块和显示:内联块之间有什么区别? 显示:内联,显示:块和显示:内联块之间有什么区别? Jul 11, 2025 am 03:25 AM

Themaindifferencesbetweendisplay:inline,block,andinline-blockinHTML/CSSarelayoutbehavior,spaceusage,andstylingcontrol.1.Inlineelementsflowwithtext,don’tstartonnewlines,ignorewidth/height,andonlyapplyhorizo​​ntalpadding/margins—idealforinlinetextstyling

造型与CSS不同访问的链接 造型与CSS不同访问的链接 Jul 11, 2025 am 03:26 AM

设置访问过链接的样式能提升用户体验,尤其在内容密集型网站中帮助用户更好导航。1.使用CSS的:visited伪类可定义已访问链接样式,如颜色变化;2.注意浏览器出于隐私限制仅允许修改部分属性;3.颜色选择应与整体风格协调,避免突兀;4.移动端可能不显示该效果,建议结合其他视觉提示如icon辅助标识。

使用CSS剪辑路径创建自定义形状 使用CSS剪辑路径创建自定义形状 Jul 09, 2025 am 01:29 AM

使用CSS的clip-path属性可以裁剪元素为自定义形状,如三角形、圆形缺口、多边形等,无需依赖图片或SVG。其优势包括:1.支持circle、ellipse、polygon等多种基本形状;2.可响应式调整,适配移动端;3.易于动画化,可结合hover或JavaScript实现动态效果;4.不影响布局流,仅裁剪显示区域。常见用法如圆形裁剪clip-path:circle(50pxatcenter)和三角形裁剪clip-path:polygon(50%0%,1000%,00%)。注意

如何使用CSS创建响应式图像? 如何使用CSS创建响应式图像? Jul 15, 2025 am 01:10 AM

要使用CSS创建响应式图片,主要可通过以下方法实现:1.使用max-width:100%和height:auto让图片在保持比例的同时自适应容器宽度;2.结合HTML的srcset和sizes属性智能加载适配不同屏幕的图片源;3.利用object-fit和object-position控制图片裁剪与焦点展示。这些方法共同确保图片在不同设备上清晰、美观地呈现。

什么是常见的CSS浏览器不一致? 什么是常见的CSS浏览器不一致? Jul 26, 2025 am 07:04 AM

不同浏览器对CSS解析存在差异,导致显示效果不一致,主要包括默认样式差异、盒模型计算方式、Flexbox和Grid布局支持程度及某些CSS属性行为不一致。1.默认样式处理不一致,解决方法是使用CSSReset或Normalize.css统一初始样式;2.旧版IE的盒模型计算方式不同,建议统一使用box-sizing:border-box;3.Flexbox和Grid在边缘情况或旧版本中表现有差异,应多测试并使用Autoprefixer;4.某些CSS属性行为不一致,需查阅CanIuse并提供降级

描述'不透明度”属性 描述'不透明度”属性 Jul 15, 2025 am 01:23 AM

opacity是CSS中用于控制元素整体透明度的属性,取值范围为0(完全透明)到1(完全不透明)。1.常用于图片hover淡出效果,通过设置opacity过渡增强交互体验;2.制作背景遮罩层提升文字可读性;3.控制按钮或图标在禁用状态下的视觉反馈。需注意它会影响所有子元素,且与rgba不同,后者仅影响指定颜色部分。搭配transition可实现平滑动画,但频繁使用可能影响性能,建议结合will-change或transform使用。合理应用opacity能增强页面层次感和交互性,但应避免干扰用户

什么是口音色的物业? 什么是口音色的物业? Jul 26, 2025 am 09:25 AM

accent-color是CSS中用于自定义复选框、单选按钮和滑块等表单元素高亮颜色的属性;1.它直接改变表单控件选中状态的默认颜色,如将复选框的蓝色勾选标记改为红色;2.支持的元素包括type="checkbox"、type="radio"和type="range"的输入框;3.使用accent-color可避免复杂的自定义样式和额外DOM结构,保持原生可访问性;4.现代浏览器普遍支持,旧浏览器需降级处理;5.设置accent-col

描述`:has()`pseudo-class(父挑选器) 描述`:has()`pseudo-class(父挑选器) Jul 15, 2025 am 12:32 AM

The:has()pseudo-classinCSSallowstargetingaparentelementbasedonitschildelements.Itworksbyusingthesyntaxparent:has(child-selector)toapplystylesconditionally.Forexample,div:has(img)appliesstylestoadivcontaininganimage.Multipleselectorscanbeusedwithcomma

See all articles