下列说法正确的是A. 基类中说明了虚函数后,派生类中与其对应的函数可不必说明为虚函数 B. 虚函数是一个非成员函数 C. 虚函数是一个static 类型的成员函数 D. 派生类的虚函数与基类的虚函数具有不同的参数个数和类型
时间: 2023-08-28 19:18:39 浏览: 170
虚基类与虚函数
0.02), np.arange(x2_min, x2_max, 0.02))
Z = np.sign(np.dot(np.c_[xxA 基类中说明了虚函数后,派生类中与其对应的函数可不必说明为虚函数,这1.ravel(), xx2.ravel()], w) + b)
Z = Z.reshape(xx1.shape)
plt.contour(xx1, xx2,个说法是正确的。派生类中与基类对应的虚函数,如果与基类虚函数的函数原 Z, colors="k", levels=[-1, 0, 1], alpha=0.5, linestyles=["--",型完全一致(包括函数名、参数列表、返回类型和 const 属性等),那么它就自动成为 "-", "--"])
# 标出支持向量
support_vectors_idx = np.where((svm.alpha > 0) & (svm.alpha <虚函数,不需要再使用 virtual 关键字来说明。例如:
```
class Base {
public:
virtual void func1();
svm.C))[0]
plt.scatter(X_train[support_vectors_idx, 0], X_train[support_vectors_idx, 1], s= virtual void func2();
};
class Derived : public Base {
public:
void func1(); // 自动成为虚函数
virtual void func3();
};
```
在这个例子中,Derived 类中的 func1() 函数与 Base 类中的 func150, facecolors='none', edgecolors='k')
support_vectors_idx = np.where(svm.alpha == svm.C)[0]
plt.scatter1() 函数的函数原型完全一致,因此它自动成为虚函数。而 func3() 函数则需要(X_train[support_vectors_idx, 0], X_train[support_vectors_idx, 1], s=150, facecolors='none',使用 virtual 关键字来说明,因为它与 Base 类中的任何函数都没有完全一致的函数原型。因此,选项 A 正确。
B. 虚函数不是一个非成员函数,它是一个成员函数 edgecolors='k')
plt.show()
# 使用模型对测试集进行预测,并评估模型性能
y_pred =,用于实现多态。
C. 虚函数不是一个 static 类型的成员函数,它是一个动态 np.sign(np.dot(X_test, w) + b)
acc = np.mean(y_test == y_pred)
precision = np.sum((y_test绑定的成员函数。static 成员函数是一个静态绑定的成员函数,它的调用在编译 == 1) & (y_pred == 1)) / np.sum(y_pred == 1)
recall = np.sum((y_test ==时就确定了。
D. 派生类的虚函数与基类的虚函数具有相同的函数原型,包 1) & (y_pred == 1)) / np.sum(y_test == 1)
f1_score = 2 * precision *括参数个数和类型。否则,派生类的函数就不会覆盖基类的函数,也不会具有多态性。
阅读全文