• <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

             

            傳統(tǒng)意義上的編譯程序分兩步走 —— 編譯和鏈接:

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

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

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

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

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

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

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

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

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

            3. 庫 (library)

            對于一個源文件很多的大項目,為了避免重復(fù)編譯,也為了方便編譯器鏈接,通常會把一些常用到的目標文件打包(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):如果庫不存在,則創(chuàng)建庫;
            標簽 r (replace):如果庫中已存在要添加的對象文件,則舊的對象文件將被替換。

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

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

            3) nm -- list symbols from object files.

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


            4. 在編譯時鏈接庫

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

            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("重復(fù)!\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;
            }  回復(fù)  更多評論
              

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久这里的只有是精品23| 97热久久免费频精品99| 精品无码久久久久久久久久| 99久久精品免费看国产免费| 狠狠色综合网站久久久久久久| 91精品国产91热久久久久福利| 99精品久久久久久久婷婷| 人妻精品久久久久中文字幕69| 国产高潮国产高潮久久久| 精品久久久久久无码免费| 香蕉久久永久视频| 久久综合中文字幕| 日韩亚洲国产综合久久久| 久久99精品久久久久久久久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久青青草视频| 亚洲AV无一区二区三区久久 | 亚洲综合精品香蕉久久网| 久久久久免费看成人影片| 日日狠狠久久偷偷色综合0| 国产成人久久AV免费| 久久精品国产亚洲αv忘忧草| 很黄很污的网站久久mimi色| 亚洲AV无码久久精品狠狠爱浪潮| 久久精品亚洲精品国产欧美| 久久午夜伦鲁片免费无码| 久久综合丝袜日本网| 亚洲精品国产综合久久一线| 国产一级持黄大片99久久| 中文精品99久久国产 | 99久久精品国内| 国产99久久久国产精品小说| 亚洲天堂久久精品| 91久久精品国产91性色也| 久久精品亚洲一区二区三区浴池| 色综合久久久久无码专区| 中文字幕精品久久久久人妻| 亚洲欧洲久久久精品| 色婷婷狠狠久久综合五月| 久久婷婷人人澡人人| 国产亚洲美女精品久久久|