• <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.從寄存器中把文件拷貝到顯示設備。
            日本高清无卡码一区二区久久| 久久久久久精品免费看SSS| 亚洲国产视频久久| 午夜久久久久久禁播电影| 久久青青草原精品影院| 久久久久亚洲精品中文字幕| 久久久久国产精品嫩草影院| 狠狠狠色丁香婷婷综合久久五月| 狠狠精品干练久久久无码中文字幕 | 久久久久国产亚洲AV麻豆| 国产精品成人精品久久久| 久久精品中文无码资源站| 国产免费久久精品丫丫| 日韩久久无码免费毛片软件| 精品熟女少妇a∨免费久久| 久久99精品久久久久久齐齐| 久久精品无码专区免费青青 | 国产精品18久久久久久vr | 伊人久久一区二区三区无码| 久久99久久99小草精品免视看| 亚洲性久久久影院| 久久精品亚洲精品国产欧美| 天天爽天天狠久久久综合麻豆| 久久噜噜久久久精品66| 天天爽天天爽天天片a久久网| 色综合久久久久久久久五月| 国产精品久久久久久久久软件| 国产99久久久国产精免费| 97精品伊人久久大香线蕉app| 无遮挡粉嫩小泬久久久久久久| 亚洲乱码日产精品a级毛片久久| 国产精品热久久无码av| 嫩草影院久久99| 国产A级毛片久久久精品毛片| 久久精品成人国产午夜| 久久精品视频网| 秋霞久久国产精品电影院| 99久久精品国产一区二区三区| 久久久精品免费国产四虎| 亚洲精品高清久久| 国产精品成人无码久久久久久 |