为什么下面的程序会出现错误?#include <iostream> #include <string> using namespace std; class A { int a; public: virtual void func() = 0; }; class B: public A { public: void func(){ cout<<"Class B"<<endl; } }; int main(int argc, char const *argv[]) { A a; a.func(); return 0; }
时间: 2024-01-14 14:02:58 浏览: 62
这段代码会出现错误,因为在main函数中创建了一个抽象类A的对象a,而抽象类是不能被实例化的。
抽象类中有一个或多个纯虚函数,这些函数没有实现,只是做了函数的声明。抽象类不能被实例化,只能作为基类,由其派生出子类,子类必须实现基类中的纯虚函数。
在这段代码中,类A是一个抽象类,它包含一个纯虚函数func,而类B是类A的子类,实现了func函数。在main函数中,创建了一个类A的对象a,但是由于类A是抽象类,无法被实例化,因此会导致编译错误。
正确的做法是创建类B的对象,然后调用其func函数,如下所示:
```
int main(int argc, char const *argv[]) {
B b;
b.func();
return 0;
}
```
相关问题
在不使用任何STL容器的前提下实现这个代码#include <iostream> #include <memory> #include <stack> #include <fstream> #include <vector> #include <cmath> #include <iomanip> #include <exception> #include <climits> #include <array> #include <cstdint> #include <string> using namespace std; class T { public: virtual bool isOperator() = 0; virtual ~T() {} };
可以使用裸指针和自定义容器实现这段代码。
首先,我们需要定义一个自定义容器来存储T类型的指针。这个容器可以使用动态数组实现,需要自己管理内存。下面是一个简单的实现:
```c++
class MyVector {
public:
MyVector() : size_(0), capacity_(0), data_(nullptr) {}
~MyVector() {
clear();
delete[] data_;
}
void push_back(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop_back() {
if (size_ > 0) {
--size_;
}
}
T* back() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
```
接下来,我们需要定义一个栈,用来存储T类型的指针。这个栈可以使用动态数组实现,也需要自己管理内存。栈的基本操作包括push、pop、top等,可以按照以下方式实现:
```c++
class MyStack {
public:
MyStack() : size_(0), capacity_(0), data_(nullptr) {}
~MyStack() {
clear();
delete[] data_;
}
void push(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop() {
if (size_ > 0) {
--size_;
}
}
T* top() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
```
最后,我们可以定义一个派生自T的类,来实现isOperator()函数。这个函数在子类中可以根据实际需求来具体实现。
```c++
class MyT : public T {
public:
bool isOperator() override {
// 实现具体的逻辑
return false;
}
};
```
这样,就可以在不使用STL容器的前提下实现这个代码了。完整代码如下:
```c++
#include <iostream>
using namespace std;
class T {
public:
virtual bool isOperator() = 0;
virtual ~T() {}
};
class MyT : public T {
public:
bool isOperator() override {
// 实现具体的逻辑
return false;
}
};
class MyVector {
public:
MyVector() : size_(0), capacity_(0), data_(nullptr) {}
~MyVector() {
clear();
delete[] data_;
}
void push_back(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop_back() {
if (size_ > 0) {
--size_;
}
}
T* back() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
class MyStack {
public:
MyStack() : size_(0), capacity_(0), data_(nullptr) {}
~MyStack() {
clear();
delete[] data_;
}
void push(T* ptr) {
if (size_ == capacity_) {
reserve(capacity_ == 0 ? 1 : capacity_ * 2);
}
data_[size_++] = ptr;
}
void pop() {
if (size_ > 0) {
--size_;
}
}
T* top() const {
return size_ > 0 ? data_[size_ - 1] : nullptr;
}
bool empty() const {
return size_ == 0;
}
void clear() {
for (int i = 0; i < size_; ++i) {
delete data_[i];
}
size_ = 0;
}
private:
void reserve(int new_capacity) {
T** new_data = new T*[new_capacity];
for (int i = 0; i < size_; ++i) {
new_data[i] = data_[i];
}
delete[] data_;
data_ = new_data;
capacity_ = new_capacity;
}
int size_;
int capacity_;
T** data_;
};
int main() {
MyVector vec;
vec.push_back(new MyT());
vec.clear();
MyStack stk;
stk.push(new MyT());
stk.clear();
return 0;
}
```
为什么以下程序会导致错误?#include <iostream> #include <string> using namespace std;class Box { int capacity; public: Box(int cap){ capacity = cap; } friend void show(); }; void Box::show() { Box b(10); cout<<"Value of capacity is: "<<b.capacity<<endl; } int main(){ show(); return 0; }
这个程序会导致错误,因为在Box类中定义了一个名为show的友元函数,但是在Box::show函数的实现中,它又创建了一个名为b的Box对象来访问capacity成员。然而,在main函数中调用的是show函数而不是Box类的对象,因此无法访问Box类的capacity成员。
要解决这个问题,你可以将Box::show函数中创建的Box对象替换为函数参数,然后将Box类的对象传递给show函数。或者你可以将Box::show函数的实现移动到main函数中,并在Box类中删除它的声明。以下是第一种解决方案的示例代码:
```c++
#include <iostream>
#include <string>
using namespace std;
class Box {
int capacity;
public:
Box(int cap) {
capacity = cap;
}
friend void show(Box obj);
};
void show(Box obj) {
cout << "Value of capacity is: " << obj.capacity << endl;
}
int main() {
Box b(10);
show(b);
return 0;
}
```
现在,你可以通过将Box类的对象传递给show函数来访问Box类的capacity成员,并且程序不会再导致错误。
阅读全文