• <em id="6vhwh"><rt id="6vhwh"></rt></em>

    <style id="6vhwh"></style>

    <style id="6vhwh"></style>
    1. <style id="6vhwh"></style>
        <sub id="6vhwh"><p id="6vhwh"></p></sub>
        <p id="6vhwh"></p>
          1. 国产亚洲欧洲av综合一区二区三区 ,色爱综合另类图片av,亚洲av免费成人在线,久久热在线视频精品视频,成在人线av无码免费,国产精品一区二区久久毛片,亚洲精品成人片在线观看精品字幕 ,久久亚洲精品成人av秋霞

            objective

            更新時間:2023-03-01 14:19:50 閱讀: 評論:0

            C語言是最經典的語言,很多其他語言的運行環境也是用C來寫的,對于寫程序的人怎么能不懂C語言呢!提到C首先必然會讓人關聯到指針,當年在大學讓你困惑的指針卻是C語言威力無窮的基礎。C語言可能從更高層面的設計和編寫效率上有所欠缺,但卻足夠經典且容易操控底層。指針雖然風險不小,但卻十分強大。此外ANSI C也增強了C程序在不同操作系統的遷移性,下面列一些C語言的一些基礎知識。

            翻譯階段

            編寫好的C程序需要先編譯成可執行的機器指令才能運行,這便是翻譯工作。翻譯的主要步驟是編譯和鏈接,編譯就是源代碼到目標代碼,而鏈接是將各個目標文件鏈接起來從而形成一個可執行的程序,當然鏈接器也會引入被程序所用到的所有標準C函數庫的函數。有時編譯過程還會將預處理作為一個階段,它主要是對源文件進行一些處理,比如將#define替換成實際值、將#include指定的文件內容填充進來。下面是使用gcc來編譯并鏈接的例子,經過編譯和鏈接后得到可執行程序,這兩個步驟通過gcc來完成,命令為gcc hello.c -o hello,最終運行./hello會輸出“hello world”。

            #include<stdio.h>int main(){ printf("hello world");}

            假如我們編寫了多個c文件,則編譯器會分別編譯成多個obj目標文件,然后再通過鏈接器將所有目標文件鏈接起來生成可執行文件。

            關于擴展名

            注意windows系統的目標文件擴展名為obj,一般鏈接完成后也不會被刪除。而unix-like系統的目標文件擴展名為o,一般在鏈接完成后會被刪除。windows系統的可執行文件擴展名為exe,而unix-like系統的可執行文件名可以任意命名。此外,C語言源文件一般后綴為c,而頭文件后綴為h,雖然沒有強制規定但大家都會去遵守這個約定。

            關于編譯器

            翻譯階段需要將C語言代碼變為可執行程序,這些工作由C編譯器完成。C編譯器也有很多,常見的如下:

            (1)GCC,GCC即(GNU Compiler Collection,GNU編譯器套件),由GNU開發的GPL許可的編譯器自由軟件。剛開始只作為C語言編譯器,但后來發展成多種語言編譯器,比如C、C++、Java、Android、Objective-C和Fortran等等?,F在很多unix-like操作系統自帶GCC,將其作為標準編譯器。

            (2)MS C,與微軟的Visual Studio一起集成發布,由微軟提供的一套完整的集成開發環境,編譯后能在微軟的所有操作系統上運行。比如VS一般會使用CL編譯器。

            (3)Clang,它是一個基于LLVM的C/C++/Objective-C輕量級編譯器,常用于Mac系統下。

            (4)Turbo C,這是一個比較流行的C編譯器,小巧快速。

            (5)cc,即C Compiler,這是一個unix系統古老的編譯器,很多經典書籍會看到這個編譯器。為保持兼容,現在的linux系統會將cc作為一個符號連接指向gcc,即/usr/bin/cc -> gcc。

            gcc編譯例子

            以linux系統的gcc為例,看幾個編譯例子。假如hello.c的代碼如下,

            #include<stdio.h>int main(){ printf("hello world");}

            我們直接使用如下的gcc命令對其進行編譯,而且不帶任何參數,此時將生成一個名為out.a的可執行文件,通過./a.out能夠輸出“hello world”。

            gcc hello.c

            假如添加name.h/name.c和adder.h/adder.c兩對頭文件和源文件,而且將hello.c稍作修改,三個文件代碼分別如下。

            //name.hchar* get_name();//name.cchar* get_name() { char* name = "aboat : "; return name;}

            //adder.hint add(int a, int b);//adder.cint add(int a, int b) { return (a + b);}

            //hello.c#include <stdio.h>#include <stdlib.h>#include <string.h>#include"adder.h"#include"name.h"int main(){ char* name = get_name(); char* hello = "hello world"; char* output = (char*)malloc(strlen(hello) + strlen(name)); sprintf(output, "%s%s", name, hello); printf("%s ", output); int a = 1; int b = 3; printf("a + b = %d ", add(a, b));}

            則通過如下的命令可以對多個源文件進行編譯和鏈接,最終生成一個名為a.out的可執行文件。當我們通過./a.out執行可執行文件時,它將輸出“aboat : hello world a + b = 4”。

            gcc name.c adder.c hello.c

            我們還可以通過下面兩個命令對name.c和adder.c兩個文件編譯生成目標文件,分別為adder.o和name.o。然后再通過下面第三行命令來編譯hello.c源文件,編譯完后它會自動與name.o和adder.o兩個目標文件進行連接。

            gcc -c adder.cgcc -c name.cgcc name.o adder.o hello.c

            此外,還能夠通過下面的命令來給多個源文件進行編譯并生成各自對應的目標文件,這意味著不對它們進行鏈接。

            gcc -c name.c adder.c hello.c

            對于多個目標文件,如果要將他們鏈接可以通過下面的命令,便能夠生成可執行文件。

            gcc name.o adder.o hello.o

            如果我們想對生成的可執行文件進行命名,那么可以通過下面第一行命令來實現,將生成一個名為hello的可執行文件。類似地,也可以對多個目標文件進行連接時指定可執行文件名,如下面第二行命令,將生成一個名為hello2的可執行文件。

            gcc name.c adder.c hello.c -o hellogcc name.o adder.o hello.o -o hello2關于字符集

            編寫C語言時源代碼可以包括如下字符集:

            英語大寫小寫字母

            A B C D E F G H I J K L M N O P Q R S T U V W X Y Za b c d e f g h i j k l m n o p q r s t u v w x y z

            十進制的阿拉伯數字

            0 1 2 3 4 5 6 7 8 9

            其它符號

            ! " # % & ' () * + , - . / :; < = > ? [ ] ^ _ { } | ~

            空白符

            空格、水平制表符、垂直制表符、換行、換頁關于注釋

            C語言提供的注釋方式有兩種:以/*開始而以*/結束來注釋多行代碼,以//開始來注釋單行代碼。一般來說對源碼中進行注釋則意味著編譯時會被預處理器清除掉,用空格來替代。

            /*第一種注釋方式*///第二種注釋方式復制代碼關于標識符與關鍵詞

            標識符就是我們開發人員對變量、函數、類型、結構體、宏等等的起名,C語言也要求我們要按照它的規定來取名。按照規定,標識符可以由英文大小寫字母(A~Z, a~z)、阿拉伯數字(0~9)、和下劃線(_)組成。需要注意以下幾點:

            (1)要求不能以字母開頭。

            (2)C語言對大小寫字母敏感。

            (3)C語言不會對標識符的長度進行限制,但標準允許編譯器忽略第31位以后的字符,具體截取前多少位則由不同的編譯器來實現,當截取的字符串相同時則認為是同一個標識符。

            (4)標識符不應該亂取名,盡量要讓標識符名字具有相應的意義。

            當然C語言還保留了32個特殊的關鍵詞,我們命名的標識符不能與它們相同,否則就會報錯。這32個關鍵詞如下:

            關鍵字說明

            對啦對啦!另外的話為了幫助大家,輕松,高效學習C語言/C++,我給大家分享我收集的資源,從最零基礎開始的,幫助大家在學習C語言的道路上披荊斬棘!可以來我粉絲群領取哦~

            編程學習書籍分享:

            編程學習視頻分享:

            整理分享(多年學習的源碼、項目實戰視頻、項目筆記,基礎入門教程)最重要的是你可以在群里面交流提問編程問題哦!

            對于C/C++感興趣可以關注小編在后臺私信我:【編程交流】一起來學習哦!可以領取一些C/C++的項目學習視頻資料哦!已經設置好了關鍵詞自動回復,自動領取就好了!

            本文發布于:2023-02-28 20:03:00,感謝您對本站的認可!

            本文鏈接:http://m.newhan.cn/zhishi/a/167765159074810.html

            版權聲明:本站內容均來自互聯網,僅供演示用,請勿用于商業和其他非法用途。如果侵犯了您的權益請與我們聯系,我們將在24小時內刪除。

            本文word下載地址:objective.doc

            本文 PDF 下載地址:objective.pdf

            上一篇:牧童古詩
            下一篇:返回列表
            標簽:objective
            相關文章
            留言與評論(共有 0 條評論)
               
            驗證碼:
            Copyright ?2019-2022 Comsenz Inc.Powered by ? 實用文體寫作網旗下知識大全大全欄目是一個全百科類寶庫! 優秀范文|法律文書|專利查詢|
            主站蜘蛛池模板: 国产亚洲午夜高清国产拍精品| 久章草在线毛片视频播放| 色www视频永久免费| 亚洲熟妇av一区二区三区宅男| 夜夜添夜夜添夜夜摸夜夜摸 | 国产综合久久亚洲综合| 亚洲精品美女久久久久9999| 久久精品无码一区二区无码| 大尺度国产一区二区视频| 国产精品国产高清国产一区| 国产精品亚洲二区在线播放| www亚洲精品| 久久久美女| 99在线小视频| 国产成人午夜福利精品| 制服丝袜美腿一区二区| 国产精品熟女孕妇一区二区| 亚洲欧美一区二区成人片 | 日韩精品亚洲专区在线播放 | 久久国产免费观看精品3| 一区二区三区四区亚洲自拍| 亚洲国内精品一区二区| 欧美视频网站www色| 久久精品国产一区二区涩涩| 熟妇的奶头又大又长奶水视频| 日本一区二区三区18岁| 亚洲性色AV一区二区三区| 亚洲中文av一区二区三区| 小罗莉极品一线天在线| 亚洲av高清一区二区| 亚洲色大成网站WWW永久麻豆| 国产亚洲精品综合99久久| 少妇被无套内谢免费看| 日本丶国产丶欧美色综合| 人妻换人妻仑乱| 欧美国产精品啪啪| 精品国产成人午夜福利| 亚洲成av人片一区二区| 成午夜精品一区二区三区 | 久久久久久人妻一区二区无码Av| 中文字幕日韩一区二区不卡 |