现代的 “Hello, World”,可不仅仅是几行代码而已
新手编写“Hello,World”程序的传统至少可以追溯到1978年。但是,对于现代的程序员而言,什么才是恰当的“Hello,World”?
不久之前,一位客户要求我在AS/400上用RPG编写程序。引用罗巴切夫斯基的话来说就是:“боже мой!”(我的天哪!)
虽然我不想暴露自己的年龄,但我上次用RPG编写程序的时候,恐怕本文的大多数读者都还没有出生。要想构建这样的程序,我需要回忆如何使用KEDIT等编辑器,学习如何使用AS/400软件开发工具、构建测试库、编辑实际的程序,然后再编译并弄清楚如何运行。
虽说客户的程序很简单,但我不想直接开始写程序。于是,我创建了一个“Hello,World”项目。
有意义的传统
“Hello,World”程序的概念可以追溯到Brian Kernighan和Dennis M. Ritchie的著作《C编程语言》(第一版),通过编写一个小程序来确认你掌握了这门语言和环境,已做好准备尝试更复杂的功能。大多数C语言程序员编写的第一个程序都像下面这样:
1 #include <stdio.h>
2
3int main() {
4 printf("Hello, world!\n");
5 return 0;
6}
将这些代码保存到‘hello.c’文件中,然后输入以下命令(在UNIX系统上):
1$ cc hello.c
2$ ./a.out
然后,你就可以看到输出结果:
1Hello, world!
以上代码可以证明你确实能够用C语言编写、编译和执行程序。
Brian Kernighan和Dennis M. Ritchie在书中写道,构建C语言的程序意味着你掌握了启动一个C语言项目的基本步骤。
这是最大的困难。为了克服这些困难,你必须能够创建程序文本,成功地编译、加载、运行并输出结果。在掌握了这些技术细节后,其他操作相对都比较容易。
好吧,我承认“其他操作相对都比较容易”这种说法略显荒诞,然而,这确实是学习所有编程语言重要的一步。
虽然编写“Hello,World”程序已成为编程界的一种传统,然而与许多传统一样,很多人虽然这么做却没有意识到其中真正的目的或价值。于是,有人在网上总结了一个Hello World集合,其中包含用近600种语言编写的“Hello,World”程序,从Ada到ZIM。许多IDE都可以编写基本的“Hello,World”程序,对于许多解释型语言(如Python)来说,“Hello,World”只不过是在解释器的REPL中键入print("Hello, world!")。
不幸的是,这并不能提供太多实际的洞察力,而用Richard Hamming的原话来说,计算的目的是洞察力,而不是文字字符串。
“Hello,World”真正的意义是什么?
原本Brian Kernighan和Dennis M. Ritchie让大家编写“Hello,World”程序的重点不是在终端上输出“Hello,World”。相反,是为了确保你具备所有的工具,并对编写C程序所需的C语言知识和UNIX编程环境有基本的了解,而且还对构建程序的工具和方法有一定的了解,这才是启动一个项目最重要的第一步。
这一步通常比最初看起来更为复杂。如今,实际的项目不仅需要编辑器和编译器,还需要了解如何打包程序,如何搭建环境,如何计划维护版本控制,如何实际构建程序以及所需交付的产品编程项目。因此,尽管基本的“Hello,World”程序可能仍然只有五行代码,但是构建最初那个看似非常容易的“ Hello,World”可能要复杂得多。
启动一个新项目必然需要在进入“其他操作相对都比较容易”阶段之前,解决许多开发上的问题。
项目的“Hello,World”程序
为了某个项目构建适当的“Hello,World”实际上比较复杂,但收益也很大。考虑一个需要交付的项目,例如一个Web应用程序。除了选择语言之外,通常还需要选择前端和后端的框架。此外,你还需要确定如何托管第一个应用程序,以及如何管理和交付代码。
对于一个项目来说,恰当的“Hello,World”程序不仅仅是显示输出。你需要证明你已做好准备添加功能(如果你们采用SCRUM则为添加用户案例),然后经过一系列的操作将其推到演示和测试的应用程序版本。对于产品而言,恰当的“Hello,World”程序就是最低版的最低可行产品,它表明随着开发的进行,你可以提供有用的产品进行测试和使用。
什么才是恰当的“Hello,World”?
显然,根据不同的项目和环境,恰当的“Hello,World”程序也有所不同。我教过很多新手,一般我都会建议他们完成以下准备工作:
一个单独的项目目录:保存所有代码的一个“文件夹”。 在这个文件夹中初始化git代码库。没错,连我都开始使用git了。虽然这些基础的知识很容易学习,但我见过很多学生陷入了绝望,因为他们做了一些小的改动,结果并没有达到预期的结果,但他们不记得做了哪些改动,无法还原到旧版本。 选择开发工具:编辑器或IDE,构建工具等等。 与在命令行中调用编译器相比,可重复的构建过程更加健壮。 然后才是实际的第一行代码。
☞出生小镇、高考不顺、复旦执教、闯荡硅谷,59 岁陆奇为何如此“幸运”?
☞DevOps 转型时如何安全融入?对企业产出有何影响?2019年 DevOps 最新现状研究报告解读 | 原力计划
☞比特币最主流,以太坊大跌,区块链技术“万金油”红利已结束 | 区块链开发者年度报告