• <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.從寄存器中把文件拷貝到顯示設備。
            久久久久久九九99精品| 色综合久久精品中文字幕首页| 青青久久精品国产免费看| 亚洲国产精品无码久久九九| 午夜人妻久久久久久久久| 久久婷婷久久一区二区三区| 亚洲欧美另类日本久久国产真实乱对白| 囯产极品美女高潮无套久久久| 久久免费高清视频| 久久亚洲日韩看片无码| 久久国产美女免费观看精品| 久久综合精品国产二区无码| 一本综合久久国产二区| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久亚洲国产精品一区二区| 久久久久se色偷偷亚洲精品av| 国产999精品久久久久久| 97久久精品无码一区二区天美| 亚洲中文字幕无码久久2017| yy6080久久| 无码人妻久久一区二区三区蜜桃| 久久精品国产一区二区三区日韩| 久久99精品国产麻豆| 色综合久久综合中文综合网| 欧美一区二区久久精品| 亚洲精品国产自在久久| 思思久久99热免费精品6| 久久综合狠狠综合久久97色| 久久精品成人欧美大片| 久久久久成人精品无码 | 久久综合狠狠综合久久| 亚洲国产精品无码久久一区二区 | 久久久91精品国产一区二区三区| 久久久久成人精品无码中文字幕| 久久精品麻豆日日躁夜夜躁| 乱亲女H秽乱长久久久| 99热成人精品热久久669| 99久久久精品免费观看国产| 精品久久8x国产免费观看| 麻豆精品久久精品色综合| 久久精品国产精品国产精品污 |