0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么要學(xué)習(xí)編譯器課程

電子工程師 ? 來源:網(wǎng)絡(luò)整理 ? 2021-03-30 10:49 ? 次閱讀

所有優(yōu)秀的計(jì)算機(jī)科學(xué)學(xué)院都提供了編譯器課程,但是相對(duì)比較少的學(xué)校把它作為本科課程的必修部分。這篇文章回答了這個(gè)問題:為什么需要學(xué)習(xí)這門課?即使你從沒打算過編寫編譯器。

我寫這篇文章的其中一個(gè)原因是,盡管我在讀本科時(shí)很喜歡編譯器課程,但是我?guī)缀蹩床坏剿膶?shí)際作用。大多數(shù)資料看起來要么簡(jiǎn)單易懂,要么很深?yuàn)W(事實(shí)上,我找到的大部分編譯器資料都是很枯燥的。)無論怎樣,我用了幾年時(shí)間總結(jié)了為什么這類課程會(huì)如此有用的實(shí)際原因。原因如下。

分析器和解析器無處不在

嚴(yán)謹(jǐn)?shù)?a href="http://ttokpm.com/v/tag/1730/" target="_blank">程序員不得不去了解分析器和解析器,因?yàn)槲覀儾粫?huì)總是只寫一些小程序。每次你寫一個(gè)可擴(kuò)展的程序或處理一種新類型的輸入文件,你都需要了解它們(分析器和解析器)。格林斯潘第十定律:

“任何C或Fortran程序復(fù)雜到一定程度之后,都會(huì)包含一個(gè)臨時(shí)的、只有一半功能的、不完全符合規(guī)格的、充滿bug的、運(yùn)行速度很慢的Common Lisp實(shí)現(xiàn)?!?/p>

我們花費(fèi)如此多的時(shí)間在這些事情上,我們可以使用一次性的小技巧來做這些事情的每一個(gè),或者我們利用60年的理論和實(shí)際知識(shí)去解決問題,并把它做對(duì)。重要的是:你應(yīng)該什么時(shí)候借用已存在的代碼或者使用已存在的工具?理論知識(shí)在什么時(shí)候可以提供幫助?哪些語(yǔ)言設(shè)計(jì)原則可以運(yùn)用在我們?nèi)粘J褂玫男≌Z(yǔ)言?

你能更好地編寫正確的代碼

編譯器應(yīng)該把輸入的語(yǔ)言正確地翻譯成合法的程序。為了達(dá)到這個(gè)目標(biāo),編譯器開發(fā)者必須了解整個(gè)輸入語(yǔ)言,包括一些普通程序員沒見過的罕見問題。這個(gè)理解過程是通往程序語(yǔ)言本質(zhì)的重要一步,它和我們平時(shí)寫代碼時(shí)所看到的不一樣。舉個(gè)例子,我在學(xué)習(xí)了順序點(diǎn)(sequence points),未定義行為(undefined behaviors),和常用的算術(shù)轉(zhuǎn)換的細(xì)節(jié)后,完全改變了我對(duì)C語(yǔ)言的理解。C編譯器編寫者已經(jīng)掌握這些概念了,但大多數(shù)初級(jí)和中級(jí)程序員都不知道這些概念。毫不夸張地說,一旦你知道語(yǔ)言的本質(zhì),你會(huì)以不同地方式和更準(zhǔn)確地思考這個(gè)語(yǔ)言。這適用于任何的語(yǔ)言,特別是像C和C++這些語(yǔ)義不清晰的語(yǔ)言。

你可以編寫更快的代碼

通過了解編譯器,你可以很清晰地知道哪些優(yōu)化是編譯器可以優(yōu)化的,和哪些是編譯器不能進(jìn)行優(yōu)化的,無論他們看起來是多么的合理和簡(jiǎn)單。你將會(huì)學(xué)到哪類代碼通常會(huì)建造最佳代碼塊,為什么會(huì)這樣和這些代碼做了什么。你會(huì)知道為什么一些代碼可以擁有更好的性能,比如使用一半寄存器組緩存濾波系數(shù)一半寄存器組緩存樣本的FIR濾波器,它和使用普通優(yōu)化器實(shí)現(xiàn)的不一樣。你和你喜歡的編譯器是一個(gè)能創(chuàng)建快速代碼的團(tuán)隊(duì),你可以使用它高效地工作,或者使用提前優(yōu)化等無意義的技巧來修改它。

其次,編譯器后端是與目標(biāo)架構(gòu)密切關(guān)聯(lián)的,當(dāng)然,現(xiàn)代的架構(gòu)都盡量提供匯編程序員友好的平臺(tái),而且離著不遠(yuǎn)了。通過理解編譯器后端和它為什么是這樣產(chǎn)生代碼的,你會(huì)對(duì)計(jì)算機(jī)架構(gòu)的操作有更好的理解。

責(zé)任編輯:lq6

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 計(jì)算機(jī)
    +關(guān)注

    關(guān)注

    19

    文章

    7360

    瀏覽量

    87633
  • 分析器
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    12479
  • 編譯器
    +關(guān)注

    關(guān)注

    1

    文章

    1617

    瀏覽量

    49015
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    C7000優(yōu)化C/C++編譯器

    電子發(fā)燒友網(wǎng)站提供《C7000優(yōu)化C/C++編譯器.pdf》資料免費(fèi)下載
    發(fā)表于 10-30 09:45 ?0次下載
    C7000優(yōu)化C/C++<b class='flag-5'>編譯器</b>

    Keil編譯器優(yōu)化方法

    我們都知道,代碼是可以通過編譯器優(yōu)化的,有的時(shí)候,為了提高運(yùn)行速度或者減少代碼尺寸,會(huì)開啟優(yōu)化選項(xiàng)。
    的頭像 發(fā)表于 10-23 16:35 ?257次閱讀
    Keil<b class='flag-5'>編譯器</b>優(yōu)化方法

    嵌入式學(xué)習(xí)-常用編輯之GCC編譯器

    、GCC編譯過程GCC編譯器編譯過程經(jīng)過預(yù)處理,編譯,匯編,鏈接等4步才能夠生成可執(zhí)行文件。預(yù)處理:主要實(shí)現(xiàn)將頭文件展開,宏定義替換以及
    發(fā)表于 08-27 10:17

    AI編譯器技術(shù)剖析

    隨著人工智能技術(shù)的飛速發(fā)展,AI編譯器作為一種新興的編譯技術(shù)逐漸進(jìn)入人們的視野。AI編譯器不僅具備傳統(tǒng)編譯器的功能,如將高級(jí)語(yǔ)言編寫的源代碼轉(zhuǎn)換為機(jī)器可執(zhí)行的代碼,還融入了人工智能技術(shù)
    的頭像 發(fā)表于 07-17 18:28 ?1409次閱讀

    人工智能編譯器與傳統(tǒng)編譯器的區(qū)別

    人工智能編譯器(AI編譯器)與傳統(tǒng)編譯器在多個(gè)方面存在顯著的差異。這些差異主要體現(xiàn)在設(shè)計(jì)目標(biāo)、功能特性、優(yōu)化策略、適用范圍以及技術(shù)復(fù)雜性等方面。以下是對(duì)兩者區(qū)別的詳細(xì)探討,旨在全面解析其內(nèi)在差異。
    的頭像 發(fā)表于 07-17 18:19 ?1611次閱讀

    深度學(xué)習(xí)編譯器和推理引擎的區(qū)別

    深度學(xué)習(xí)編譯器和推理引擎在人工智能領(lǐng)域中都扮演著至關(guān)重要的角色,但它們各自的功能、應(yīng)用場(chǎng)景以及優(yōu)化目標(biāo)等方面存在顯著的差異。以下是對(duì)兩者區(qū)別的詳細(xì)探討。
    的頭像 發(fā)表于 07-17 18:12 ?1175次閱讀

    Meta發(fā)布基于Code Llama的LLM編譯器

    近日,科技巨頭Meta在其X平臺(tái)上正式宣布推出了一款革命性的LLM編譯器,這一模型家族基于Meta Code Llama構(gòu)建,并融合了先進(jìn)的代碼優(yōu)化和編譯器功能。LLM編譯器的推出,標(biāo)志著Meta在人工智能領(lǐng)域的又一重大突破,將
    的頭像 發(fā)表于 06-29 17:54 ?1430次閱讀

    SEGGER編譯器優(yōu)化和安全技術(shù)介紹 支持最新C和C++語(yǔ)言

    SEGGER編譯器是專門為ARM和RISC-V微控制設(shè)計(jì)的優(yōu)化C/C++編譯器。它建立在強(qiáng)大的Clang前端上,支持最新的C和C++語(yǔ)言功能。 除其他外,其主要功能包括: 1)?尺寸優(yōu)化:通過調(diào)整
    的頭像 發(fā)表于 06-04 15:31 ?1363次閱讀
    SEGGER<b class='flag-5'>編譯器</b>優(yōu)化和安全技術(shù)介紹 支持最新C和C++語(yǔ)言

    C語(yǔ)言:嵌入式開發(fā)中的關(guān)鍵編譯器角色

    嵌入式程序開發(fā)跟硬件密切相關(guān),需要使用C語(yǔ)言來讀寫底層寄存、存取數(shù)據(jù)、控制硬件等,C語(yǔ)言和硬件之間由編譯器來聯(lián)系,一些C標(biāo)準(zhǔn)不支持的硬件特性操作,由編譯器提供。
    發(fā)表于 04-26 14:53 ?509次閱讀
    C語(yǔ)言:嵌入式開發(fā)中的關(guān)鍵<b class='flag-5'>編譯器</b>角色

    QT開發(fā)學(xué)習(xí)筆記1(安裝交叉編譯器

    QT安裝交叉編譯器
    的頭像 發(fā)表于 02-18 10:02 ?834次閱讀
    QT開發(fā)<b class='flag-5'>學(xué)習(xí)</b>筆記1(安裝交叉<b class='flag-5'>編譯器</b>)

    Embedded Studio 編譯器教程

    最近入手先輯的HPM6750,需要使用Embedded Studio 編譯器來做開發(fā),各位推薦一下學(xué)習(xí)資料。
    發(fā)表于 02-04 08:01

    Triton編譯器的原理和性能

    Triton是一種用于編寫高效自定義深度學(xué)習(xí)原語(yǔ)的語(yǔ)言和編譯器。Triton的目的是提供一個(gè)開源環(huán)境,以比CUDA更高的生產(chǎn)力編寫快速代碼,但也比其他現(xiàn)有DSL具有更大的靈活性。Triton已被采用
    的頭像 發(fā)表于 12-16 11:22 ?2645次閱讀
    Triton<b class='flag-5'>編譯器</b>的原理和性能

    TVM編譯器的整體架構(gòu)和基本方法

    有將近兩個(gè)月沒有學(xué)習(xí)一些新東西,更新一下博客了。一直在忙公司的一個(gè)項(xiàng)目,是做一款支持LSTM和RNN的通用架構(gòu)加速IP。自己恰好負(fù)責(zé)指令編譯工作,雖然開始的指令比較粗糙,沒有一套完整的編譯器架構(gòu)
    的頭像 發(fā)表于 11-30 09:36 ?2235次閱讀
    TVM<b class='flag-5'>編譯器</b>的整體架構(gòu)和基本方法

    為什么C語(yǔ)言進(jìn)行編譯

    為什么我們編寫的C語(yǔ)言進(jìn)行編譯?什么是編譯?編譯時(shí)發(fā)生了什么? 機(jī)器無法理解我們編寫的C語(yǔ)言,而編譯就是將面向人類的高級(jí)語(yǔ)言轉(zhuǎn)換成為面向機(jī)
    的頭像 發(fā)表于 11-24 15:47 ?1200次閱讀
    為什么C語(yǔ)言<b class='flag-5'>要</b>進(jìn)行<b class='flag-5'>編譯</b>

    編譯器的優(yōu)化選項(xiàng)

    一個(gè)程序首先要保證正確性,在保證正確性的基礎(chǔ)上,性能也是一個(gè)重要的考量。編寫高性能的程序,第一,必須選擇合適的算法和數(shù)據(jù)結(jié)構(gòu);第二,應(yīng)該編寫編譯器能夠有效優(yōu)化以轉(zhuǎn)換成高效可執(zhí)行代碼的源代碼,要做到
    的頭像 發(fā)表于 11-24 15:37 ?838次閱讀
    <b class='flag-5'>編譯器</b>的優(yōu)化選項(xiàng)