繁体   English   中英

C ++将一组对象传递给抽象类的成员函数

[英]C++ Passing a set of objects to a member functions of abstract class

我想将对象传递给类的成员函数并从其中执行一些函数。 当我使用* myCars指针执行此操作时,一切正常。 但是,当我尝试通过此操作对纯虚拟类执行相同操作时,程序将返回错误(请参阅解决方案A)。 我有一个临时解决方案(请参阅解决方案B),但对我来说似乎不合适。 有解决的办法吗?

main.cpp中

#include <iostream>
#include "car.h"
#include "veicles.h"
#include "traffic.h"

int main(){

        int number = 3;
        Car *myCars = new Car[number];

        Traffic mtc;
        mtc.import(myCars, number);

        Veicles *myVeicles = new Car[number];

//      Solution A
//      Traffic mtvA;
//      mtvA.import(myVeicles, number);

//      Solution B
        std::cout << "\nsolution B\n";
        Traffic mtvB;
        mtvB.import(&myVeicles, number);

        delete[] myCars;
        delete[] myVeicles;

        return 0;
}

car.h

#ifndef CAR_H
#define CAR_H

#include <iostream>
#include "veicles.h"

class Car : public Veicles{
public:
    void move();

};

#endif

car.cpp

#include "car.h"

void Car::move(){

        std::cout << "the car is moving\n";
}

traffic.h

#ifndef TRAFFIC_H
#define TRAFFIC_H

#include "car.h"

class Traffic{
public:

    void import(Car p[], int number);
    void import(Veicles *v[], int number);
private:

    Veicles *vc;

};

#endif

traffic.cpp

#include "traffic.h"
#include "car.h"

void Traffic::import(Car p[], int number){

        for(int i = 0; i < number; i++){
                p[i].move();
        }
} 

void Traffic::import(Veicles *v[], int number){

        vc = *v; 
        for(int i = 0; i < number; i++){
               // vc -> move();
               vc[i].move(); //  EDIT: R Sahu sugestion
        }
}

veicles.h

#ifndef VEICLES_H
#define VEICLES_H

class Veicles{
public:

    virtual void move() = 0;
};

#endif

veicles.cpp

#include "veicles.h"

// some stuffs to do latter..

生成文件

all:    clean car veicles traffic main
        g++ car.o traffic.o main.o -o main.out
run:
        ./main.out

car:    car.h
        g++ -c car.cpp -o car.o

veicles: car.h veicles.h
        g++ -c veicles.cpp -o veicles.o

traffic: traffic.h car.h
        g++ -c traffic.cpp -o traffic.o


main: traffic.h car.h
        g++ -c main.cpp -o main.o

clean:
        rm -f *.o
        rm -f *.gch
  void import(Car p[], int number);

是相同的

  void import(Car* p, int number);

您不能使用Vehicle*类型的参数来调用它,因为不能将基类指针自动转换为派生类指针。

假设您有:

class Truck : public Veicles{
 ...
};

Veicles *myVeicles = new Truck[number];

如果编译器允许您调用该函数,则您将突然能够在需要Car地方使用Truck 那会导致灾难。


以下功能有效

void Traffic::import(Veicles *v[], int number){
   vc = *v; 
   for(int i = 0; i < number; i++){
      vc -> move();
   }
}

但是,请注意,您没有使用i访问vc的元素。 您仅在第一个对象上调用move()

以下将是一个问题。

void Traffic::import(Veicles *v[], int number){
   vc = *v; 
   for(int i = 0; i < number; i++){
      vc[i].move();
   }
}

这样做的原因是您可能不会将派生类对象的数组视为基类对象的数组。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM