linux開篇

在很多人的眼裏,C語言和linux常常是分不開的。這其中的原因很多,其中最重要的一部分我認爲是linux本身就是C語言的傑出作品。當然,linux操作系統本身對C語言的支持也是相當到位的。作爲一個真正的程序員來說,如果沒有在linux下面用C語言編寫過完整的程序,那麼只能說他對C語言本身的理解還相關膚淺,對系統本身的認識也不夠到位。作爲程序員來說,linux系統爲我們提供了很多理想的環境,這其中包括了下面幾個方面,
    
    (1)完善的編譯環境,包括gcc、as、ld等編譯、鏈接工具
    (2)強大的調試環境,主要是gdb工具
    (3)豐富的自動編譯工具,主要是make工具
    (4)多樣化的os選擇,ubuntu、redflag等等
    (5)浩瀚的開源代碼庫

    當然,不管我怎麼說,最終朋友們還是應該自己勇敢地跨出前進的第一步。如果還沒有過Linux編程經驗的朋友可以首先在自己的pc上面安裝一個虛擬機,然後就可以在shell下面編寫自己的C語言代碼了。

[cpp] view plain copy
  1. #include <stdio.h>  
  2.   
  3. int main()  
  4. {  
  5.     printf("hello!\n");  
  6.     return 1;  
  7. }    
    編寫完上面的代碼後,你需要做的就是兩個步驟:1、輸入 gcc hello.c -o hello;2、輸入./hello。如果一切正常的話,此時你應該會在屏幕上看到一行hello的打印。如果你看到了,那麼恭喜你,你已經可以開始linux的c語言編程之旅了。

    當然,我們不會滿足於這麼簡單的打印功能。下面就可以編寫一個簡單的迭代函數,
[cpp] view plain copy
  1. #include <stdio.h>  
  2.   
  3. int iterate(int value)  
  4. {  
  5.     if(1 == value)  
  6.         return 1;  
  7.     return iterate(value - 1) + value;  
  8. }  
  9.   
  10. int main()  
  11. {  
  12.     printf("%d\n", iterate(10));  
  13.     return 1;      
  14. }  
    此時,同樣我們需要重複上面的步驟:1、輸入gcc hello.c -o hello;2、輸入./hello。當然此時如果一切OK的話,你就會看到屏幕會有55這個數的輸出。本來1到10的數據之和就是55, 這說明我們的程序是正確的。

    當然, 還會有一些朋友對程序的反彙編感興趣,那麼他需要兩個步驟:1、gcc hello.c -g -o hello;2、objdump -S -d ./hello。之所以在gcc編譯的時候加上-g是爲了添加調試信息,objdump中的-S選項是爲了在顯示彙編代碼的時候同時顯示原來的C語言源代碼。
[cpp] view plain copy
  1. int iterate(int value)  
  2. {  
  3.  8048374:       55                      push   %ebp  
  4.  8048375:       89 e5                   mov    %esp,%ebp  
  5.  8048377:       83 ec 08                sub    $0x8,%esp  
  6.     if(1 == value)  
  7.  804837a:       83 7d 08 01             cmpl   $0x1,0x8(%ebp)  
  8.  804837e:       75 09                   jne    8048389 <iterate+0x15>  
  9.         return 1;  
  10.  8048380:       c7 45 fc 01 00 00 00    movl   $0x1,0xfffffffc(%ebp)  
  11.  8048387:       eb 16                   jmp    804839f <iterate+0x2b>  
  12.     return iterate(value -1) + value;  
  13.  8048389:       8b 45 08                mov    0x8(%ebp),%eax  
  14.  804838c:       83 e8 01                sub    $0x1,%eax  
  15.  804838f:       89 04 24                mov    %eax,(%esp)  
  16.  8048392:       e8 dd ff ff ff          call   8048374 <iterate>  
  17.  8048397:       8b 55 08                mov    0x8(%ebp),%edx  
  18.  804839a:       01 c2                   add    %eax,%edx  
  19.  804839c:       89 55 fc                mov    %edx,0xfffffffc(%ebp)  
  20.  804839f:       8b 45 fc                mov    0xfffffffc(%ebp),%eax  
  21. }  
  22.  80483a2:       c9                      leave  
  23.  80483a3:       c3                      ret  
  24.     


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章