欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++的靜態(tài)聯(lián)編和動態(tài)聯(lián)編詳解

 更新時間:2014年07月21日 17:57:57   投稿:shichen2014  
這篇文章主要介紹了C++的靜態(tài)聯(lián)編和動態(tài)聯(lián)編詳解,對于深入理解C++編譯運行原理有很大幫助,需要的朋友可以參考下

一、概述:

通常來說聯(lián)編就是將模塊或者函數(shù)合并在一起生成可執(zhí)行代碼的處理過程,同時對每個模塊或者函數(shù)調(diào)用分配內(nèi)存地址,并且對外部訪問也分配正確的內(nèi)存地址,它是計算機程序彼此關聯(lián)的過程。按照聯(lián)編所進行的階段不同,可分為兩種不同的聯(lián)編方法:靜態(tài)聯(lián)編動態(tài)聯(lián)編。

靜態(tài)聯(lián)編是指在編譯階段就將函數(shù)實現(xiàn)和函數(shù)調(diào)用關聯(lián)起來,因此靜態(tài)聯(lián)編也叫早綁定,在編譯階段就必須了解所有的函數(shù)或模塊執(zhí)行所需要檢測的信息,它對函數(shù)的選擇是基于指向?qū)ο蟮闹羔槪ɑ蛘咭茫┑念愋停?span style="color: #ff0000">C語言中,所有的聯(lián)編都是靜態(tài)聯(lián)編,并且任何一種編譯器都支持靜態(tài)聯(lián)編。

動態(tài)聯(lián)編是指在程序執(zhí)行的時候才將函數(shù)實現(xiàn)和函數(shù)調(diào)用關聯(lián),因此也叫運行時綁定或者晚綁定,動態(tài)聯(lián)編對函數(shù)的選擇不是基于指針或者引用,而是基于對象類型,不同的對象類型將做出不同的編譯結(jié)果C++中一般情況下聯(lián)編也是靜態(tài)聯(lián)編,但是一旦涉及到多態(tài)和虛擬函數(shù)就必須要使用動態(tài)聯(lián)編了。下面將介紹一下多態(tài)。

多態(tài):字面的含義是具有多種形式或形態(tài)。C++多態(tài)有兩種形式,動態(tài)多態(tài)和靜態(tài)多態(tài);動態(tài)多態(tài)是指一般的多態(tài),是通過類繼承和虛函數(shù)機制實現(xiàn)的多態(tài);靜態(tài)多態(tài)是通過模板來實現(xiàn),因為這種多態(tài)實在編譯時而非運行時,所以稱為靜態(tài)多態(tài)

二、代碼實例:

動態(tài)多態(tài)實例如下:

#include <stdio.h>
#include <iostream>
/** 
*Shape
*/
class CShape
{
public:
 CShape(){}
 virtual ~CShape(){}
 virtual void Draw() = 0;
};
/**
*Point
*/
class CPoint : public CShape
{
public:
 CPoint(){}
 ~CPoint(){}
 void Draw()
 {
 printf("Hello! I am Point!/n");
 }
};
/**
*Line
*/
class CLine : public CShape
{
public:
 CLine(){}
 ~CLine(){}
 void Draw()
 {
 printf("Hello! I am Line!/n");
 }
};

void main()
{
 CShape* shape = new CPoint();
 //draw point
 shape->Draw();//在這里shape將會調(diào)用CPoint的Draw()函數(shù)
 delete shape;
 shape = new CLine();
 //draw Line
 shape->Draw();//而在這里shape將會調(diào)用CLIne 的Draw()函數(shù)
 delete shape;
 return ;
}

大家可以考慮一下它的輸出結(jié)果,如果實在不知道,那就麻煩你運行一下它吧!
由上面的例子,大家應該能理解什么是多態(tài)了:也就是一個Draw() 可以有兩種實現(xiàn),并且是在運行時決定的,在編譯階段不知道,也不可能知道!只有在運行的時候才能知道我們生成的shape是那種圖形,當然要實現(xiàn)這種效果就需要動態(tài)聯(lián)編了,在基類我們會把想要多態(tài)的函數(shù)聲明為虛函數(shù),而虛函數(shù)的實現(xiàn)原理就使用了動態(tài)聯(lián)編。如果你想了解的更透徹,那就上網(wǎng)查查資料吧!在這里我就不再啰嗦虛函數(shù)的實現(xiàn)原理了。

這里也提供一個靜態(tài)多態(tài)的例子:

在上面例子的基礎之上添加模板函數(shù):

template <class T>
void DrawShape(T* t)
{
 t->Draw();
}

修改main函數(shù)為如下:

void main()
{
 CShape* shape = new CPoint();
 //draw point
 shape->Draw();
 DrawShape<CPoint>((CPoint*)shape);
 delete shape;
 shape = new CLine();
 //draw Line
 shape->Draw();
 DrawShape<CLine>((CLine*)shape);
 delete shape;
 
 return ;
}

在程序編譯main函數(shù)的時候,編譯器就已經(jīng)指定了DrawShape函數(shù)里面的Draw要調(diào)用那個實現(xiàn)了,這就是靜態(tài)多態(tài),在編譯時就已經(jīng)知道了要調(diào)用的函數(shù)。

相關文章

  • C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作

    C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作

    這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之串插入操作的相關資料,希望通過本文能幫助到大家,讓大家實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-10-10
  • C程序中唯一序列號的生成實例詳解

    C程序中唯一序列號的生成實例詳解

    這篇文章主要介紹了C程序中唯一序列號的生成實例詳解的相關資料,需要的朋友可以參考下
    2017-06-06
  • C語言判斷字符是否為可打印字符的方法

    C語言判斷字符是否為可打印字符的方法

    這篇文章主要介紹了C語言判斷字符是否為可打印字符的方法,分別為isprint()函數(shù)和isgraph()函數(shù)的使用,需要的朋友可以參考下
    2015-08-08
  • C語言實現(xiàn)BST二叉排序樹的基本操作

    C語言實現(xiàn)BST二叉排序樹的基本操作

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)BST二叉排序樹的基本操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C++ 前置聲明詳解及實例

    C++ 前置聲明詳解及實例

    這篇文章主要介紹了C++ 前置聲明詳解及實例的相關資料,需要的朋友可以參考下
    2017-06-06
  • C++的內(nèi)存管理詳細解釋

    C++的內(nèi)存管理詳細解釋

    這篇文章主要介紹了C/C++中的內(nèi)存管理小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-09-09
  • C++實現(xiàn)LeetCode(15.三數(shù)之和)

    C++實現(xiàn)LeetCode(15.三數(shù)之和)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(三數(shù)之和),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 利用C++編寫一個Json解析器

    利用C++編寫一個Json解析器

    這篇文章主要為大家詳細介紹了如何利用C++編寫一個簡單又好用的Json解析器,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2023-03-03
  • C語言文件操作函數(shù)大全(超詳細)

    C語言文件操作函數(shù)大全(超詳細)

    本篇文章是對C語言中的文件操作函數(shù)進行了詳細的總結(jié)分析,需要的朋友參考下
    2013-05-05
  • C++中的throw關鍵字詳解

    C++中的throw關鍵字詳解

    throw關鍵字是在C語言中用來拋出異常的關鍵字,它通常與try和catch一起使用,用于在程序中發(fā)生錯誤時進行異常處理,當遇到無法處理的錯誤情況時,我們可以使用throw關鍵字主動拋出異常,所以本文給大家詳細的介紹一下C++中的throw關鍵字,需要的朋友可以參考下
    2023-09-09

最新評論