阿爾弗雷德·阿霍和杰弗里·烏爾曼因?yàn)樵诰幊陶Z(yǔ)言領(lǐng)域的研究獲得了今年計(jì)算機(jī)科學(xué)界的諾貝爾獎(jiǎng)——圖靈獎(jiǎng)。
阿霍和烏爾曼已經(jīng)合作了30多年,合著了一系列關(guān)于編程語(yǔ)言、數(shù)據(jù)和算法的奠基性教科書,塑造了一整代計(jì)算機(jī)科學(xué)家的思維。他們?cè)诰幾g器理論方面的研究尤其出名。編譯器是一種將指令從抽象的編程語(yǔ)言(如數(shù)據(jù)庫(kù)專用語(yǔ)言SQL)轉(zhuǎn)換為計(jì)算機(jī)可以執(zhí)行的機(jī)器碼的軟件。
“阿霍和烏爾曼建立了關(guān)于算法、形式語(yǔ)言、編譯器和數(shù)據(jù)庫(kù)的基本原理,對(duì)于今天編程和軟件環(huán)境的發(fā)展至關(guān)重要?!苯芊颉さ隙髡f,他是一位享譽(yù)盛名的谷歌工程師兼高管,現(xiàn)在是谷歌的高級(jí)研究員以及谷歌研究和谷歌健康的高級(jí)副總裁。
圖靈獎(jiǎng)每年由美國(guó)計(jì)算機(jī)協(xié)會(huì)(ACM)頒發(fā)。獲獎(jiǎng)?wù)邔⒎窒?00萬(wàn)美元獎(jiǎng)金,由谷歌資助。該獎(jiǎng)項(xiàng)以開創(chuàng)了現(xiàn)代計(jì)算機(jī)基礎(chǔ)的英國(guó)數(shù)學(xué)家阿蘭·圖靈命名。
今年的圖靈獎(jiǎng)獲獎(jiǎng)?wù)甙⒒艉蜑鯛柭暮献鹘?jīng)歷始于上世紀(jì)60年代末的貝爾實(shí)驗(yàn)室,當(dāng)時(shí)兩人都已獲得了普林斯頓大學(xué)的博士學(xué)位。他們最初的研究重點(diǎn)是開發(fā)更高效的算法和翻譯編程語(yǔ)言。盡管烏爾曼1969年離開了貝爾實(shí)驗(yàn)室回到學(xué)術(shù)界,并最終在斯坦福大學(xué)任教(目前是該校的名譽(yù)教授),但兩人仍繼續(xù)一起寫書。
1974年,他們出版了《計(jì)算機(jī)算法的設(shè)計(jì)與分析》(The Design and Analysis of Computer Algorithms),十多年來,這本書一直是算法課程的標(biāo)準(zhǔn)教科書。該書將單個(gè)算法劃分為更一般的設(shè)計(jì)類別,至今仍在該領(lǐng)域發(fā)揮著巨大的影響。
三年后,阿霍和烏爾曼出版了《編譯器設(shè)計(jì)原理》(Principles of Compiler Design),再次成為經(jīng)典之作,教導(dǎo)一代又一代的學(xué)生如何創(chuàng)建編譯器,如何思考計(jì)算機(jī)語(yǔ)言理論。這本書被計(jì)算機(jī)科學(xué)專業(yè)的學(xué)生稱為“龍之書”,因?yàn)榉饷嫔嫌×艘粭l龍,看起來就像哈利·波特會(huì)在霍格沃茨帶著走來走去的魔法大部頭,只不過那時(shí)候哈利波特這個(gè)虛擬人物還沒有誕生。 “我經(jīng)常聽人說,因?yàn)檫@個(gè)有趣的封面,“龍之書”更能吸引學(xué)生來學(xué)習(xí)計(jì)算機(jī)科學(xué)?!睘鯛柭f,“很多學(xué)生喜歡在校園里夾著這本怪書的感覺?!?/p>
阿霍在貝爾實(shí)驗(yàn)室工作了30多年,目前是哥倫比亞大學(xué)的計(jì)算機(jī)科學(xué)名譽(yù)教授,他說自己在這家著名的企業(yè)實(shí)驗(yàn)室工作期間,親身感受到了設(shè)計(jì)編程語(yǔ)言的重要性,可以讓需要使用電腦在數(shù)學(xué)、化學(xué)或排版等特定領(lǐng)域開展工作的人無需成為電腦運(yùn)行專家就可以出色完成工作。烏爾曼將創(chuàng)建編程語(yǔ)言的藝術(shù)描述為“讓程序員說最少的話,實(shí)現(xiàn)盡可能多的功能。”
阿霍和烏爾曼都表示,回顧自己的職業(yè)生涯,最滿足的是看到自己對(duì)教過和指導(dǎo)過的學(xué)生產(chǎn)生的影響,他們的學(xué)生中有許多人現(xiàn)在在大型科技公司擔(dān)任高級(jí)職位,發(fā)明了數(shù)不盡的編程語(yǔ)言。谷歌聯(lián)合創(chuàng)始人謝爾蓋·布林就是烏爾曼的博士生。
阿霍說,教授學(xué)生編程語(yǔ)言和算法的理論基礎(chǔ)非常重要,部分原因是語(yǔ)言本身往往會(huì)受到流行趨勢(shì)的影響?!叭绻纯磳W(xué)術(shù)界優(yōu)先教給學(xué)生的編程語(yǔ)言,你會(huì)發(fā)現(xiàn)它一直在變化?!彼赋??!耙婚_始是C或C++,之后開始流行Pascal,現(xiàn)在Python似乎是第一選擇。誰(shuí)知道10年后、100年后、1000年后會(huì)是什么樣子?”他補(bǔ)充道,“我們都認(rèn)為,基本原理和抽象概念比眼下的技術(shù)更有生命力。”(財(cái)富中文網(wǎng))
譯者:Agatha
阿爾弗雷德·阿霍和杰弗里·烏爾曼因?yàn)樵诰幊陶Z(yǔ)言領(lǐng)域的研究獲得了今年計(jì)算機(jī)科學(xué)界的諾貝爾獎(jiǎng)——圖靈獎(jiǎng)。
阿霍和烏爾曼已經(jīng)合作了30多年,合著了一系列關(guān)于編程語(yǔ)言、數(shù)據(jù)和算法的奠基性教科書,塑造了一整代計(jì)算機(jī)科學(xué)家的思維。他們?cè)诰幾g器理論方面的研究尤其出名。編譯器是一種將指令從抽象的編程語(yǔ)言(如數(shù)據(jù)庫(kù)專用語(yǔ)言SQL)轉(zhuǎn)換為計(jì)算機(jī)可以執(zhí)行的機(jī)器碼的軟件。
“阿霍和烏爾曼建立了關(guān)于算法、形式語(yǔ)言、編譯器和數(shù)據(jù)庫(kù)的基本原理,對(duì)于今天編程和軟件環(huán)境的發(fā)展至關(guān)重要。”杰夫·迪恩說,他是一位享譽(yù)盛名的谷歌工程師兼高管,現(xiàn)在是谷歌的高級(jí)研究員以及谷歌研究和谷歌健康的高級(jí)副總裁。
圖靈獎(jiǎng)每年由美國(guó)計(jì)算機(jī)協(xié)會(huì)(ACM)頒發(fā)。獲獎(jiǎng)?wù)邔⒎窒?00萬(wàn)美元獎(jiǎng)金,由谷歌資助。該獎(jiǎng)項(xiàng)以開創(chuàng)了現(xiàn)代計(jì)算機(jī)基礎(chǔ)的英國(guó)數(shù)學(xué)家阿蘭·圖靈命名。
今年的圖靈獎(jiǎng)獲獎(jiǎng)?wù)甙⒒艉蜑鯛柭暮献鹘?jīng)歷始于上世紀(jì)60年代末的貝爾實(shí)驗(yàn)室,當(dāng)時(shí)兩人都已獲得了普林斯頓大學(xué)的博士學(xué)位。他們最初的研究重點(diǎn)是開發(fā)更高效的算法和翻譯編程語(yǔ)言。盡管烏爾曼1969年離開了貝爾實(shí)驗(yàn)室回到學(xué)術(shù)界,并最終在斯坦福大學(xué)任教(目前是該校的名譽(yù)教授),但兩人仍繼續(xù)一起寫書。
1974年,他們出版了《計(jì)算機(jī)算法的設(shè)計(jì)與分析》(The Design and Analysis of Computer Algorithms),十多年來,這本書一直是算法課程的標(biāo)準(zhǔn)教科書。該書將單個(gè)算法劃分為更一般的設(shè)計(jì)類別,至今仍在該領(lǐng)域發(fā)揮著巨大的影響。
三年后,阿霍和烏爾曼出版了《編譯器設(shè)計(jì)原理》(Principles of Compiler Design),再次成為經(jīng)典之作,教導(dǎo)一代又一代的學(xué)生如何創(chuàng)建編譯器,如何思考計(jì)算機(jī)語(yǔ)言理論。這本書被計(jì)算機(jī)科學(xué)專業(yè)的學(xué)生稱為“龍之書”,因?yàn)榉饷嫔嫌×艘粭l龍,看起來就像哈利·波特會(huì)在霍格沃茨帶著走來走去的魔法大部頭,只不過那時(shí)候哈利波特這個(gè)虛擬人物還沒有誕生。 “我經(jīng)常聽人說,因?yàn)檫@個(gè)有趣的封面,“龍之書”更能吸引學(xué)生來學(xué)習(xí)計(jì)算機(jī)科學(xué)。”烏爾曼說,“很多學(xué)生喜歡在校園里夾著這本怪書的感覺。”
阿霍在貝爾實(shí)驗(yàn)室工作了30多年,目前是哥倫比亞大學(xué)的計(jì)算機(jī)科學(xué)名譽(yù)教授,他說自己在這家著名的企業(yè)實(shí)驗(yàn)室工作期間,親身感受到了設(shè)計(jì)編程語(yǔ)言的重要性,可以讓需要使用電腦在數(shù)學(xué)、化學(xué)或排版等特定領(lǐng)域開展工作的人無需成為電腦運(yùn)行專家就可以出色完成工作。烏爾曼將創(chuàng)建編程語(yǔ)言的藝術(shù)描述為“讓程序員說最少的話,實(shí)現(xiàn)盡可能多的功能。”
阿霍和烏爾曼都表示,回顧自己的職業(yè)生涯,最滿足的是看到自己對(duì)教過和指導(dǎo)過的學(xué)生產(chǎn)生的影響,他們的學(xué)生中有許多人現(xiàn)在在大型科技公司擔(dān)任高級(jí)職位,發(fā)明了數(shù)不盡的編程語(yǔ)言。谷歌聯(lián)合創(chuàng)始人謝爾蓋·布林就是烏爾曼的博士生。
阿霍說,教授學(xué)生編程語(yǔ)言和算法的理論基礎(chǔ)非常重要,部分原因是語(yǔ)言本身往往會(huì)受到流行趨勢(shì)的影響。“如果看看學(xué)術(shù)界優(yōu)先教給學(xué)生的編程語(yǔ)言,你會(huì)發(fā)現(xiàn)它一直在變化?!彼赋觥!耙婚_始是C或C++,之后開始流行Pascal,現(xiàn)在Python似乎是第一選擇。誰(shuí)知道10年后、100年后、1000年后會(huì)是什么樣子?”他補(bǔ)充道,“我們都認(rèn)為,基本原理和抽象概念比眼下的技術(shù)更有生命力?!保ㄘ?cái)富中文網(wǎng))
譯者:Agatha
Alfred Aho and Jeffrey Ullman have won this year’s Turing Award, computer science’s equivalent of the Nobel Prize, for their work on programming languages.
Through more than three decades of collaboration, Aho and Ullman coauthored a series of seminal textbooks on programming languages, data, and algorithms that shaped the thinking of a generation of computer scientists. They are particularly known for their work on the theory of compilers, a type of software that converts instructions from an abstract programming language, such as the database-specific language SQL, into the machine code that the computer executes.
“Aho and Ullman established bedrock ideas about algorithms, formal languages, compilers, and databases, which were instrumental in the development of today’s programming and software landscape,” said Jeff Dean, a storied Google engineer and executive who is currently the company’s senior fellow and senior vice president at Google Research and Google Health.
The Turing Award is given annually by the Association for Computing Machinery (ACM). The winners share a $1 million prize, which Google helps fund. The prize is named for Alan Turing, the British mathematician who developed the foundations of modern computing.
This year’s Turing winners began their collaboration at Bell Labs in the late 1960s, after both received Ph.D.s from Princeton University. They initially worked on developing more efficient algorithms and translating programming languages. Although Ullman left Bell Labs to return to academia in 1969, eventually ending up at Stanford University, where he is currently a professor emeritus, the two continued to write books together.
In 1974, they published The Design and Analysis of Computer Algorithms, which became the standard textbook for courses on algorithms for more than a decade. The book was influential for grouping individual algorithms into more general design categories which continued to exert great influence on the field.
Three years later, Aho and Ullman published Principles of Compiler Design, which also became a classic, teaching generations of students how to create compilers and how to think about the theory of computer languages. The textbook became known as “the Dragon Book” among computer science students because it featured a dragon on its cover, resembling some magical tome Harry Potter might cart around Hogwarts, except the fictional wizard hadn’t been invented yet. “I am often told that putting this funny cover on the Dragon Book attracted students to study computer science,” Ullman says. “A lot of students liked the idea of walking around campus with this weird book under their arm.”
Aho, who worked at Bell Labs for more than 30 years and is currently a computer science professor emeritus at Columbia University, says that while at the famed corporate lab he saw firsthand the importance of designing programming languages that would work well for people who needed computers to perform work in a specific field, such as mathematics or chemistry or typesetting, without having to be experts in how computers functioned. Ullman describes the art of creating programming languages as “enabling the programmer to say as little as possible and have as much happen as possible.”
Both Aho and Ullman say that when they look back on their careers, they are most gratified by the impact they have had on students they have taught and mentored, many of whom now hold senior posts at major technology companies and have invented numerous programming languages. Among Ullman’s Ph.D. students was Google cofounder Sergey Brin.
Aho says that it was important to give students a grounding in the theory of programming languages and algorithms, in part because the languages themselves tend to be subject to changing fashion. “If you look at the first programming languages taught to students in academia, it changes all the time,” he notes. “It was C or C++, and then Pascal was popular, and now Python seems to be the first programming language. Who knows what it will be 10 years from now, 100 years from now, 1,000 years from now?” He adds, “We both feel fundamentals and abstractions have more staying power than the technology of the moment.”