吴忠躺衫网络科技有限公司

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

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

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

解答編譯器是怎樣運(yùn)行的

GReq_mcu168 ? 來(lái)源:碼農(nóng)的荒島求生 ? 作者:碼農(nóng)的荒島求生 ? 2021-03-09 15:20 ? 次閱讀

對(duì)于程序員來(lái)說(shuō)編譯器是非常熟悉的,每天都在用,但是當(dāng)你在點(diǎn)擊“Run”這個(gè)按鈕或者執(zhí)行編譯命令時(shí)你知道編譯器是怎樣工作的嗎?

這篇文章就為你解答這個(gè)問(wèn)題。

編譯器就是一個(gè)普通程序,沒(méi)什么大不了的

什么是編譯器?

編譯器是一個(gè)將高級(jí)語(yǔ)言翻譯為低級(jí)語(yǔ)言的程序。

首先我們一定要意識(shí)到編譯器就是一個(gè)普通程序,沒(méi)什么大不了的。

在沒(méi)有弄明白編譯器如何工作之前你可以簡(jiǎn)單的把編譯器當(dāng)做一個(gè)黑盒子,其作用就是輸入一個(gè)文本文件輸出一個(gè)二進(jìn)制文件。

基本上編譯器經(jīng)過(guò)了以下幾個(gè)階段,等等,這句話教科書(shū)上也有,但是我相信很多同學(xué)其實(shí)并沒(méi)有真正理解這幾個(gè)步驟到底在說(shuō)些什么,為了讓你徹底理解這幾個(gè)步驟,我們用一個(gè)簡(jiǎn)單的例子來(lái)講解。

假定我們有一段程序:

while (y < z) { int x = a + b; y += x;}

那么編譯器是怎樣把這一段程序人類認(rèn)識(shí)的程序轉(zhuǎn)換為CPU認(rèn)識(shí)的二進(jìn)制機(jī)器指令呢?

提取出每一個(gè)單詞:詞法分析

首先編譯器要把源代碼中的每個(gè)“單詞”提取出來(lái),在編譯技術(shù)中“單詞”被稱為token。其實(shí)不只是每個(gè)單詞被稱為一個(gè)token,除去單詞之外的比如左括號(hào)、右括號(hào)、賦值操作符等都被稱為token。

從源代碼中提取出token的過(guò)程就被稱為詞法分析,Lexical Analysis。

經(jīng)過(guò)一遍詞法分析,編譯器得到了以下token:

T_While whileT_LeftParen (T_Identifier yT_Less

就這樣一個(gè)磁盤(pán)中保存的字符串源代碼文件就轉(zhuǎn)換為了一個(gè)個(gè)的token。

這些token想表達(dá)什么意思:語(yǔ)法分析

有了這些token之后編譯器就可以根據(jù)語(yǔ)言定義的語(yǔ)法恢復(fù)其原本的結(jié)構(gòu),怎么恢復(fù)呢?

原來(lái),編譯器在掃描出各個(gè)token后根據(jù)規(guī)則將其用樹(shù)的形式表示出來(lái),這顆樹(shù)就被稱為語(yǔ)法樹(shù)。

語(yǔ)法樹(shù)是不是合理的:語(yǔ)義分析

有了語(yǔ)法樹(shù)后我們還要檢查這棵樹(shù)是不是合法的,比如我們不能把一個(gè)整數(shù)和一個(gè)字符串相加、比較符左右兩邊的數(shù)據(jù)類型要相同,等等。

這一步通過(guò)后就證明了程序合法,不會(huì)有編譯錯(cuò)誤。

根據(jù)語(yǔ)法樹(shù)生成中間代碼:代碼生成

語(yǔ)義分析之后接下來(lái)編譯器遍歷語(yǔ)法樹(shù)并用另一種形式來(lái)表示,用什么來(lái)表示呢?那就是中間代碼,intermediate representation code,簡(jiǎn)稱IR code

上述語(yǔ)法樹(shù)可能就會(huì)表示為這樣的中間代碼:

Loop: x = a + b y = x + y _t1 = y < z if _t1 goto Loop

怎么樣,這實(shí)際上已經(jīng)比較接近最后的機(jī)器指令了。

只不過(guò)這還不是最終形態(tài)。

中間代碼優(yōu)化

在生成中間代碼后要對(duì)其進(jìn)行優(yōu)化,我們可以看到,實(shí)際上可以把x = a + b這行代碼放到循環(huán)外,因?yàn)槊看窝h(huán)都不會(huì)改變x的值,因此優(yōu)化后就是這樣了:

x = a + bLoop: y = x + y _t1 = y < z if _t1 goto Loop

中間代碼優(yōu)化后就可以生成機(jī)器指令了。

代碼生成

將上述優(yōu)化后的中間代碼轉(zhuǎn)換為機(jī)器指令:

add $1, $2, $3Loop: add $4, $1, $4 slt $6, $1, $5 beq $6, loop

最終,編譯器將程序員認(rèn)識(shí)的代碼轉(zhuǎn)換為了CPU認(rèn)識(shí)的機(jī)器指令。

總結(jié)

注意這篇簡(jiǎn)短的講解不希望給大家留下這樣的印象,那就是編譯器是很簡(jiǎn)單的,恰恰相反,現(xiàn)代編譯器是非常智能并且極其復(fù)雜的,絕不是短短一篇文章就能講清楚的,能實(shí)現(xiàn)一個(gè)編譯器是困難的,實(shí)現(xiàn)一個(gè)好的編譯器更是難上加難。

本文的目的旨在以極簡(jiǎn)的方式描述編譯器的工作原理,這樣你就不用把編譯器當(dāng)做一個(gè)黑盒了,希望這篇文章能對(duì)你有所幫助。
編輯:lyn

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

    關(guān)注

    1

    文章

    1642

    瀏覽量

    49286

原文標(biāo)題:編譯器是如何工作的

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    什么樣的代碼會(huì)被編譯器優(yōu)化

    現(xiàn)在的編譯器有多智能,可能你辛辛苦苦寫(xiě)的代碼,在編譯器看來(lái)就是幾句廢話,直接被刪除掉。
    的頭像 發(fā)表于 01-16 16:38 ?185次閱讀

    Triton編譯器與GPU編程的結(jié)合應(yīng)用

    Triton編譯器簡(jiǎn)介 Triton編譯器是一種針對(duì)并行計(jì)算優(yōu)化的編譯器,它能夠自動(dòng)將高級(jí)語(yǔ)言代碼轉(zhuǎn)換為針對(duì)特定硬件優(yōu)化的低級(jí)代碼。Triton編譯器的核心優(yōu)勢(shì)在于其能夠識(shí)別并行模式,
    的頭像 發(fā)表于 12-25 09:13 ?324次閱讀

    Triton編譯器如何提升編程效率

    在現(xiàn)代軟件開(kāi)發(fā)中,編譯器扮演著至關(guān)重要的角色。它們不僅將高級(jí)語(yǔ)言代碼轉(zhuǎn)換為機(jī)器可執(zhí)行的代碼,還通過(guò)各種優(yōu)化技術(shù)提升程序的性能。Triton 編譯器作為一種先進(jìn)的編譯器,通過(guò)多種方式提升編程效率,使得
    的頭像 發(fā)表于 12-25 09:12 ?335次閱讀

    Triton編譯器在高性能計(jì)算中的應(yīng)用

    高性能計(jì)算(High-Performance Computing,HPC)是現(xiàn)代科學(xué)研究和工程計(jì)算中不可或缺的一部分。隨著計(jì)算需求的不斷增長(zhǎng),對(duì)計(jì)算資源的要求也越來(lái)越高。Triton編譯器作為一種
    的頭像 發(fā)表于 12-25 09:11 ?358次閱讀

    Triton編譯器的優(yōu)化技巧

    在現(xiàn)代計(jì)算環(huán)境中,編譯器的性能對(duì)于軟件的運(yùn)行效率至關(guān)重要。Triton 編譯器作為一個(gè)先進(jìn)的編譯器框架,提供了一系列的優(yōu)化技術(shù),以確保生成的代碼既高效又適應(yīng)不同的硬件架構(gòu)。 1. 指令
    的頭像 發(fā)表于 12-25 09:09 ?340次閱讀

    Triton編譯器的優(yōu)勢(shì)與劣勢(shì)分析

    Triton編譯器作為一種新興的深度學(xué)習(xí)編譯器,具有一系列顯著的優(yōu)勢(shì),同時(shí)也存在一些潛在的劣勢(shì)。以下是對(duì)Triton編譯器優(yōu)勢(shì)與劣勢(shì)的分析: 優(yōu)勢(shì) 高效性能優(yōu)化 : Triton編譯器
    的頭像 發(fā)表于 12-25 09:07 ?389次閱讀

    Triton編譯器在機(jī)器學(xué)習(xí)中的應(yīng)用

    1. Triton編譯器概述 Triton編譯器是NVIDIA Triton推理服務(wù)平臺(tái)的一部分,它負(fù)責(zé)將深度學(xué)習(xí)模型轉(zhuǎn)換為優(yōu)化的格式,以便在NVIDIA GPU上高效運(yùn)行。Triton編譯器
    的頭像 發(fā)表于 12-24 18:13 ?518次閱讀

    Triton編譯器支持的編程語(yǔ)言

    Triton編譯器支持的編程語(yǔ)言主要包括以下幾種: 一、主要編程語(yǔ)言 Python :Triton編譯器通過(guò)Python接口提供了對(duì)Triton語(yǔ)言和編譯器的訪問(wèn),使得用戶可以在Python環(huán)境中
    的頭像 發(fā)表于 12-24 17:33 ?461次閱讀

    Triton編譯器與其他編譯器的比較

    Triton編譯器與其他編譯器的比較主要體現(xiàn)在以下幾個(gè)方面: 一、定位與目標(biāo) Triton編譯器 : 定位:專注于深度學(xué)習(xí)中最核心、最耗時(shí)的張量運(yùn)算的優(yōu)化。 目標(biāo):提供一個(gè)高度抽象、靈活、高效
    的頭像 發(fā)表于 12-24 17:25 ?484次閱讀

    Triton編譯器功能介紹 Triton編譯器使用教程

    Triton 是一個(gè)開(kāi)源的編譯器前端,它支持多種編程語(yǔ)言,包括 C、C++、Fortran 和 Ada。Triton 旨在提供一個(gè)可擴(kuò)展和可定制的編譯器框架,允許開(kāi)發(fā)者添加新的編程語(yǔ)言特性和優(yōu)化技術(shù)
    的頭像 發(fā)表于 12-24 17:23 ?642次閱讀

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

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

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

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

    人工智能編譯器與傳統(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 ?2119次閱讀

    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 ?1566次閱讀

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

    QT安裝交叉編譯器
    的頭像 發(fā)表于 02-18 10:02 ?1127次閱讀
    QT開(kāi)發(fā)學(xué)習(xí)筆記1(安裝交叉<b class='flag-5'>編譯器</b>)
    北京太阳城国际老年公寓| 百家乐官网娱乐下载| 青海省| 民丰县| 博狗百家乐官网开户| 真人百家乐官网是骗局| 百家乐官网在线作弊| 真人百家乐官网分析软件是骗局| 百家乐官网轮盘桌| 百家乐官网庄闲符号记| 伟易博百家乐官网娱乐城| 风水24山辛山乙| 真钱百家乐官网开户试玩| 百家乐官网投注法减注| 在线百家乐官网平台| 嘉黎县| 百家乐官网大眼仔小路| 百家乐官网玩法教程| 新花园百家乐官网的玩法技巧和规则 | 大发888线上| 大发888出纳柜台| 唐朝百家乐的玩法技巧和规则| 大发888真钱电玩游戏| 爱博| 有百家乐官网的游戏平台| 君怡百家乐官网的玩法技巧和规则 | 大上海百家乐的玩法技巧和规则 | 百家乐官网概率投注| 蒙特卡罗网址| 谈谈百家乐官网赢钱技巧| 百家乐官网平注法是什么| 博彩百家乐官网的玩法技巧和规则 | 百家乐网上娱乐场开户注册 | 贵族百家乐的玩法技巧和规则 | 百家乐官网论坛官网| 百家乐庄闲收益率| 百家乐加牌规| 西充县| 百家乐官网的各种打法| 玩百家乐官网的好处| 最佳场百家乐的玩法技巧和规则|