首页 > 其他分享 >46.动态联编和静态联编

46.动态联编和静态联编

时间:2022-10-17 22:14:48浏览次数:40  
标签:函数 联编 void Dog 46 Animal 静态 speak

1.动态联编和静态联编(重点难点)

1.静态联编

编译器会根据函数调用的对象类型,在编译阶段就确定函数的调用地址,这就是静态联编(早绑定)

2.虚函数

在普通成员函数前面加virtual,该函数变为虚函数,是告诉编译器这个函数要晚绑定

3.动态联编

在运行阶段才确定调用哪个函数(晚绑定),

4.动态编译的作用,可以晚绑定函数调用地址,这样可以扩展功能,不修改前面的代码的基础上进行项目的扩充

5.类型转换问题

​ 1.子类转换成父类(向上转换):编译器认为指针的寻址范围缩小了,所以是安全的

​ 2.父类转换成子类(向下转换);编译器认为指针的寻址范围扩大了,不安全

2.视频内容

程序1:

#pragma warning(disable:4996)
#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;

class Animal
{
public:
    void speak()
    {
        cout << "Animal speak " << endl;
    }
};

void test()
{
    Animal an;
    an.speak();//在编译阶段就确定调用speak这个函数
}

int main()
{
    test();
    system("pause");
    return EXIT_SUCCESS;
}

输出结果:

Animal speak
请按任意键继续. . .


程序2:

#pragma warning(disable:4996)
#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;

class Animal
{
public:
    //虚函数
    void speak()
    {
        cout << "Animal speak " << endl;
    }
};

class Dog: public Animal
{
public:
    void speak()
    {
        cout << "Dog speak" << endl;
    }
};

void doLogin(Animal *animal)
{
    animal->speak();
}
void test01()
{
    Animal an;
    an.speak();//在编译阶段就确定调用speak这个函数
}

void test02()
{
    Dog *dog = new Dog;
    doLogin(dog);
}

int main()
{
    test02();
    system("pause");
    return EXIT_SUCCESS;
}

输出结果:

Animal speak
请按任意键继续. . .


程序3:

#pragma warning(disable:4996)
#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;

class Animal
{
public:
    //虚函数
    virtual void speak()
    {
        cout << "Animal speak " << endl;
    }
};

class Dog: public Animal
{
public:
    void speak()
    {
        cout << "Dog speak" << endl;
    }
};

void doLogin(Animal *animal)
{
    animal->speak();
}
void test01()
{
    Animal an;
    an.speak();//在编译阶段就确定调用speak这个函数
}

void test02()
{
    Dog *dog = new Dog;
    doLogin(dog);
}

int main()
{
    test02();
    system("pause");
    return EXIT_SUCCESS;
}

输出结果:

Dog speak
请按任意键继续. . .


程序4:

#pragma warning(disable:4996)
#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;

class Animal
{
public:
    //虚函数
    virtual void speak()
    {
        cout << "Animal speak " << endl;
    }
};

class Dog: public Animal
{
public:
    void speak()
    {
        cout << "Dog speak" << endl;
    }
};

class Dog1: public Animal
{
public:
    void speak()
    {
        cout << "Dog1 speak" << endl;
    }
};

void doLogin(Animal *animal)
{
    animal->speak();
}
void test01()
{
    Animal an;
    an.speak();//在编译阶段就确定调用speak这个函数
}

void test02()
{
    Dog *dog = new Dog;
    doLogin(dog);

    Dog1 *dog1 = new Dog1;
    doLogin(dog1);
}

int main()
{
    test02();
    system("pause");
    return EXIT_SUCCESS;
}

输出结果:

Dog speak
Dog1 speak
请按任意键继续. . .

标签:函数,联编,void,Dog,46,Animal,静态,speak
From: https://www.cnblogs.com/codemagiciant/p/16800892.html

相关文章

  • java 静态代码块 非静态代码块
    java中的静态代码块在类加载的时候调用(只调用一次),普通代码块在创建对象(只要创建新的对象都会调用一次)的时候调用,普通代码快的调用在构造方法之前publicclassPuTong......
  • 一篇文章让你搞懂Java中的静态代理和动态代理
    什么是代理模式代理模式是常用的java设计模式,在Java中我们通常会通过new一个对象再调用其对应的方法来访问我们需要的服务。代理模式则是通过创建代理类(proxy)的方式间......
  • winioctl.h(10326): [C4668] 没有将“_WIN32_WINNT_WIN10_TH2”定义为预处理器宏,用
    一般为Windows中的宏和UE4冲突所致在模块的xxx.Build.cs里面添加这个:bEnableUndefinedIdentifierWarnings=false;转自:https://blog.csdn.net/boonti/article/detail......
  • CF463C 题解
    题目传送门题目分析贪心练手好题。首先,国际象棋中象的走法是斜着走,也就是这样:通过上面的图我们不难看出,如果一个象在黑格,另外一个在白格,那么它们之间一定不会互相攻击......
  • CF1468A
    设\(f_i\)表示以第\(i\)个结尾,强制选第\(i\)个所能得到的最长几乎上升序列的长度。则\(f_i=\max\limits_{j\lti,a_j\lea_i}\left\{f_j+1+w(i,j)\right\}\)。其......
  • Java 静态类、静态方法和静态变量
    (37条消息)Java静态类、静态方法和静态变量_winfredzen的博客-CSDN博客_静态方法在加载的时候会执行return(37条消息)java中引用数据类型有哪些?_xiaoming3526的博客-CS......
  • CF1746D(记忆化搜索,DP,贪心)
    CF1746D(记忆化搜索,DP,贪心)https://codeforces.com/contest/1746/problem/d题意给一棵树,树上每个点有一个权值\(s_i\),有一个整数\(k\)。表示从根节点出发的简单路径的......
  • CF1746C(构造)
    CF1746C(构造)https://codeforces.com/contest/1746/problem/c题意给一个排列,进行\(n\)次操作,第\(i\)次操作可以将任意指定长度的后缀加\(i\)。问经过\(n\)次操......
  • 【HTML+CSS】静态网页设计期末大作业——艺术官网17页
    ......
  • [题解] Codeforces Global Round 23 1746 A B C D E1 F 题解
    点我看题求点赞A.Maxmina首先序列全0的情况肯定是NO。否则,如果\(k\ge3\),则在序列中随便找一个1,把他左边和右边分别用第一种操作不断缩,直到序列长度为k为止,最后用一次2......