• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 6, comments - 0, trackbacks - 0, articles - 0
              程序是如何運行的

            作為一個程序員,已不知編了多少行代碼。但若問我程序是如何在計算機中運行的,我怕只有張口結舌。書中第一章就給了我們相關的答案。

            首先,看如下最簡單的C語言Helloword的代碼

             

            1#include <stdio.h>
            2
            3int main()
            4{
            5   printf("hello, world\n");
            6}
            上面的代碼我們保存在helloworld.c文件中。其本質實際上是由0、1的比特(位)序列構成的。8位為一個字節。每個字節對應某個文本字符。不少系統用ASCII來表示文本字符。實際是由一個唯一的同字節大小的整數值來表示每個字符。下面給出helloworld.c的ASCII表示。
            #      i         n        c       l       u       d      e     <sp>   <     s     t        d        i       o      .
            35   105    110    99    108  117  100   101   32     60  115  116   100   105  111  46
            h       >      \n       \n      i        n      t     <sp>   m      a      i       n       (       )      \n     {
            104  62     10     10     105  110  116   32    109    97   105  110   40    41   10   123
            \n     <sp> <sp> <sp> <sp>   p      r      i       n        t       f      (       "      h       e       l
            10    32     32     32     32    112  114  105  110    116  102  40    34   104   101   108
            l       o       ,        <sp>  w      o      r       l      d        \       n       "       )       ;       \n      }
            108 111    44     32     119  111  114  108  100    92    110  34    41   59      10     125
            以此類推,在計算機系統中,任何介質中的數據都是比特序列。把他們區分成不同的數據對象,是通過數據對象的上下文來確定的。

            程序編譯
            程序的編譯過程如下圖所示,分為預處理、編譯、匯編、鏈接等幾個階段。

            預處理:預處理相當于根據預處理命令組裝成新的C程序,不過常以i為擴展名。
            編譯:    將得到的i文件翻譯成匯編代碼。s文件。
            匯編:    將匯編文件翻譯成機器指令,并打包成可重定位目標程序的O文件。該文件是二進制文件,字節編碼是機器指令。
            鏈接:    將引用的其他O文件并入到我們程序所在的o文件中,處理得到最終的可執行文件。

            硬件組成:
            從下圖中看出一個典型的系統由總線、Cpu、I/O設備、主存等構成。

            CPU: Central Processing Unit,  ALU: Arithmetic/Logic Unit,  PC: Program counter,  USB: Universal Serial Bus.

            程序執行
            我們已經討論了可執行文件產生的過程。接下來討論哈可執行文件執行的過程。從上面途中的彩色線條可以清晰的看到這個過程,我們簡單的把它分為6步。
            1.shell程序執行指令,等待用戶輸入,這里我們輸入“hello”。
            2.shell程序將字符逐一讀到寄存器中
            3.再從寄存器取出放到主存中
            4.當我們敲入回車時,shell程序得知輸入結束,將hello目標文件的代碼和數據拷貝到主存,從而加載hello文件數據包括最終被輸出的字符串“hello,world\n”.利用了DMA訪問技術,數據可不經CPU直接到主存
            5.執行主程序中的機器語言指令,將“hello,world\n”串的字節從主存拷貝到寄存器堆。
            6.從寄存器中把文件拷貝到顯示設備。
            国产精品成人久久久| 久久er99热精品一区二区| 久久亚洲高清观看| 久久精品免费一区二区三区| 久久国产精品99精品国产| 99久久精品日本一区二区免费| 久久综合久久自在自线精品自| 久久天天躁狠狠躁夜夜躁2O2O| 久久精品亚洲日本波多野结衣| 久久精品国内一区二区三区| 国产成人99久久亚洲综合精品| 青青草原综合久久大伊人导航| 久久精品卫校国产小美女| 国内精品久久久久影院一蜜桃| 久久99精品久久久久久不卡| 日韩AV毛片精品久久久| 亚洲AV无码久久精品色欲| 久久精品国产亚洲沈樵| 99久久国产亚洲综合精品| 精品乱码久久久久久久| 性做久久久久久免费观看| 国产午夜免费高清久久影院| 久久国产影院| 久久久久久久97| 久久综合久久综合亚洲| 香蕉久久夜色精品国产小说| 久久99九九国产免费看小说| 国产高潮国产高潮久久久| 精品久久久久久久国产潘金莲| 韩国免费A级毛片久久| 久久亚洲AV无码精品色午夜麻豆| 婷婷久久综合九色综合98| 狠狠综合久久综合88亚洲| 午夜精品久久久久久| 久久精品国产亚洲沈樵| 亚洲国产精品无码久久久蜜芽| 久久精品夜色噜噜亚洲A∨ | 国产成人无码精品久久久性色| 日本精品久久久久中文字幕| 久久99精品久久只有精品| 亚洲欧洲日产国码无码久久99|