• <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 李陽 閱讀(25330) 評論(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;
            }  回復  更多評論
              
            久久久久人妻一区二区三区vr| 久久综合精品国产一区二区三区| 亚洲精品tv久久久久久久久| 久久久久九九精品影院| AAA级久久久精品无码区| 久久国产成人精品麻豆| 久久天堂电影网| 欧美国产精品久久高清| 亚洲午夜久久久久久噜噜噜| 亚洲AV无码久久精品色欲| 久久综合九色综合欧美狠狠| 欧美久久久久久精选9999| 精品多毛少妇人妻AV免费久久 | 久久精品人人做人人爽97| 日韩精品久久久久久| 久久亚洲精品无码观看不卡| 一本久久知道综合久久| 国产ww久久久久久久久久| 亚洲精品视频久久久| 奇米综合四色77777久久| 久久播电影网| 久久久久久精品无码人妻| 日韩精品久久久久久| 少妇高潮惨叫久久久久久| 精品久久久久久无码中文野结衣 | 精品久久久久久久久中文字幕| 国产精品久久久久久久久鸭| 亚洲欧美久久久久9999 | 亚洲精品乱码久久久久久蜜桃图片 | 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久99九九国产免费看小说| 久久精品亚洲中文字幕无码麻豆| 久久久99精品成人片中文字幕| 精品无码久久久久久午夜| 欧美日韩精品久久免费| 精品综合久久久久久88小说 | 久久精品国产男包| 久久这里只精品99re66| 久久久国产一区二区三区| 美女写真久久影院| 国产精品免费福利久久|