- 當派生類是以公有方式繼承時,用戶代碼才能使用派生類向基類的轉換,否則用戶代碼不可完成轉換
- 無論派生類是以哪種方式繼承,派生類的成員函數和友元函數都可以完成派生類向基類的轉換。
- 設派生類是D, 基類是B, 當以protected方式繼承時,D的派生類的成員函數和友元可以完成派生類向基類的轉換, 但是如果D繼承B 的方式是private則不可以。
代碼寫得有點噁心
#include <iostream>
#include <string.h>
#include <algorithm>
#include <stdlib.h>
#include <stdio.h>
using namespace std;
void func();
class A{
public:
int a;
void get(){
cout<<"A "<<": "<<a<<endl;
}
};
class B : public A{
public:
int b;
void getB(){
cout<<"b : "<< b<<endl;
}
void getA(A &a){
cout<<"getA :"<<a.a<<endl;
}
};
class C: protected A{
public :
int c;
void getC(){
cout<<" c "<<c<<endl;
}
void inputA(int n){
a = n;
}
void getA( C & cc){
A aa = (C) cc;
cout<<"getA :" <<aa.a<<endl;
}
friend void func(C c);
};
class D: private A{
public:
int d;
void getD(){
cout<<"D "<<d<<endl;
}
void getA(D &d){
A aa = (A) d;
cout<<"getA :" <<aa.a<<endl;
}
void setA(int b){
a = b;
}
friend void func(D d);
};
void func(D d){
A aa = (A) d;
cout<<"friend "<<aa.a<<endl;
}
void func(C c){
A aa = (A) c;
cout<<"friend "<<aa.a<<endl;
}
void get(A &a){
a.get();
}
class E : protected B{
};
int main(){
B b;
A a;
C c;
D d;
a.a = 1;
b.a = 2;
c.c = 3;
c.inputA(3);
d.setA(4);
func(d);
}