• <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>
            隨筆-4  評論-40  文章-117  trackbacks-0

             

            傳統意義上的編譯程序分兩步走 —— 編譯和鏈接:

            1.編譯(compile):指用編譯器(compiler)將源代碼(source code)生成二進制目標文件(object file),在Windows下也就是 .obj 文件,UNIX下是 .o 文件。編譯時,編譯器需要的是語法的正確,函數與變量的聲明的正確,編譯器只檢測程序語法,和函數、變量是否被聲明,函數并不需要被定義。

                UNIX下g++的語法為:
                    g++ -c file.cpp

                -c 是compile的意思,此命令將會生成 file.o 的目標文件。

            2.鏈接(link):找到所要用到函數所在的目標文件,并把它們鏈接在一起合成為可執行文件(executable file)。鏈接時,要確保編譯器能找到所有被用到了的函數所在的目標文件。

                g++ file1.o file2.o -o program.exe

                -o 是指定生成的可執行文件名稱(output)。若不給出,默認的名稱為 a.out

            上述兩部通常也可以合在一起完成:

                g++ file1.cpp file2.cpp -o program.exe

            這完全等同于上面兩步的結合,會先生成目標文件,然后鏈接成 file.exe

            3. 庫 (library)

            對于一個源文件很多的大項目,為了避免重復編譯,也為了方便編譯器鏈接,通常會把一些常用到的目標文件打包(archive),于是就成為了傳說中的庫文件(library)。在Windows下這種包叫“庫文件”(Library File),也就是 .lib 文件,在UNIX下,是Archive File,也就是 .a 文件。

            UNIX 所要用到的命令:
            1)ar -- create, modify, and extract from archives.
            @Usage: ar cr lib****.a file1.o file2.o
            **** 為自定義的庫文件名。
            標簽 c (create):如果庫不存在,則創建庫;
            標簽 r (replace):如果庫中已存在要添加的對象文件,則舊的對象文件將被替換。

            實際上 ar 只是一個打包工具,是archive(打包)的首字母。它將一系列的目標文件首位連接在一起,并內嵌一個索引表,使得編譯器能夠方便地找到所需要的函數。一般來說,由于函數索引表的存在,對庫的鏈接要比對一般的對象文件的鏈接更快。如果 ar 未能完成此項索引表工作,還可以手動用以下的 ranlib 命令創建索引表。

            2) ranlib -- generate index to archive.
            @Usage: ranlib lib****.a

            3) nm -- list symbols from object files.

            nm可以用來顯示 ranlib 所構建的索引表。你將會看到所有庫里的函數名(除了模板函數template function)。


            4. 在編譯時鏈接庫

            創建了自己的庫,以后要用到相關函數的時候,只需在代碼中聲明所要用的函數(必須和庫中定義得相同)。在鏈接的時候,需要給出庫的名稱和位置:

            g++ file1.o file2.o -o program.exe -L**** -l****

            -L 后緊跟庫文件所在的目錄地址,-l 后緊跟庫名。

            編譯器在鏈接的時候會在所指定的目錄地址下尋找名為 lib****.a 的庫文件。
             
             

            posted on 2010-04-29 13:31 李陽 閱讀(25364) 評論(1)  編輯 收藏 引用

            評論:
            # re: g++ 編譯和鏈接 2015-07-09 10:57 | 李然
            #include<stdio.h>
            #include<malloc.h>
            #include<string.h>
            typedef char ElemType;

            typedef struct Lnode
            {
            ElemType data[30];
            struct Lnode *next;
            }LinkList;

            LinkList *InitList()
            {
            LinkList *L;
            L=(LinkList *)malloc(sizeof(LinkList));
            L->next=NULL;
            return L;
            }

            int Insert(LinkList *L,int i,ElemType e[30])
            {
            int j=0,len=0;
            LinkList *p=L,*s;
            if (i == 0) return 0;
            while (p && j < i - 1)
            {
            p = p->next;
            j++;
            }
            if (p == NULL) return 0;
            if (p->next == NULL && j < i - 1) return 0;
            s = (LinkList *)malloc(sizeof(LinkList));
            strcpy(s->data,e);
            s->next = p->next;
            p->next = s;
            return 1;
            /*while(p->next!=NULL)
            {
            if(strcmp(p->next->data,e)==0)
            {
            printf("重復!\n");
            return ;
            }
            p=p->next;
            len++;
            }
            if(L->next->data==NULL)
            {
            if(i!=1)
            {
            printf("空鏈表,輸入位置有誤!\n");
            return ;
            }
            s=(LinkList *)malloc(sizeof(LinkList));
            strcpy(s->data,e);
            s->next=p->next;
            p->next=s;
            }
            else if(i<=0 || len<i-1)
            {
            printf("位置不合法!\n");
            return ;
            }
            else
            {
            p=L;
            j=0;
            while(j<i-1)
            {
            p=p->next;
            j++;
            }
            s=(LinkList *)malloc(sizeof(LinkList));
            strcpy(s->data,e);
            s->next=p->next;
            p->next=s;
            }
            return ;*/
            }

            void Search(LinkList *L,ElemType e[30])
            {
            LinkList *p=L->next;
            int i=1;
            while(p->next!=NULL && (strcmp(p->data,e)!=0))
            {
            p=p->next;
            i++;
            }
            if(strcmp(p->data,e)==0)
            {
            printf("%d\n",i);
            }
            else printf("查找對象不存在!\n");
            }

            void Delete(LinkList *L,ElemType e[30])
            {
            LinkList *p=L,*s;
            if(!L) return;
            while(p->next!=NULL && (strcmp(p->next->data,e)!=0))
            {
            p=p->next;
            }
            if(strcmp(p->next->data,e)==0)
            {
            s=p->next;
            p->next=s->next;
            }
            else printf("刪除對象不存在!\n");
            }

            void Show(LinkList *L)
            {
            LinkList *q;
            q=L->next;
            while(q!=NULL)
            {
            printf("%s ",q->data);
            q=q->next;
            }
            printf("\n");
            }

            int main()
            {
            int i;
            char mean[10],e[30];
            LinkList *L;
            L=InitList();
            L->next=NULL;
            while(scanf("%s",mean)==1)
            {
            if(strcmp(mean,"insert")==0)
            {
            scanf("%d",&i);
            scanf("%s",e);
            Insert(L,i,e);
            }
            if(strcmp(mean,"deletes")==0)
            {
            scanf("%s",e);
            Delete(L,e);
            }
            if(strcmp(mean,"search")==0)
            {
            scanf("%s",e);
            Search(L,e);
            }
            if(strcmp(mean,"show")==0)
            {
            Show(L);
            }
            }
            return 0;
            }  回復  更多評論
              
            99久久婷婷国产综合精品草原| 色婷婷综合久久久久中文字幕 | 99热都是精品久久久久久| 99久久精品无码一区二区毛片| 伊人热人久久中文字幕| 午夜精品久久影院蜜桃| 99久久99这里只有免费费精品| 久久影视综合亚洲| 久久久精品人妻一区二区三区四| 久久久精品视频免费观看| 久久99国产精品尤物| 欧美午夜精品久久久久久浪潮| 无码超乳爆乳中文字幕久久| 性做久久久久久久久久久| 国产情侣久久久久aⅴ免费| 国产成人久久精品麻豆一区| 久久久噜噜噜久久中文福利| 久久青青草原精品国产不卡| 久久久国产精品福利免费| 久久婷婷国产综合精品| 久久免费看黄a级毛片| 91精品国产高清久久久久久国产嫩草 | 波多野结衣中文字幕久久| 亚洲精品无码久久毛片| 久久亚洲国产精品五月天婷| 久久综合九色综合网站 | 久久久久人妻精品一区| 亚洲婷婷国产精品电影人久久| 亚洲精品高清国产一久久| 久久99热精品| 久久精品国产99久久香蕉| 久久福利青草精品资源站免费| 欧美亚洲色综久久精品国产| 婷婷伊人久久大香线蕉AV | 亚洲国产另类久久久精品黑人 | 久久综合亚洲色HEZYO国产| 狠狠色丁香婷婷久久综合不卡| 国产69精品久久久久777| 91久久精品91久久性色| 久久久91精品国产一区二区三区| 国产精品一区二区久久精品|