프로그램 설계 실습 MOOC/프로그램 설계와 알고리즘 (3) 제04주 테스트(2020 봄) 002: 구덩이가 좋아 보이는 연산자 재부팅

5160 단어
제목 올리기
    #include <iostream> 
    using namespace std;
    class MyInt 
    { 
    	int nVal; 
    	public: 
    	MyInt( int n) { nVal = n ;}

//          

    }; 
    int Inc(int n) {
    	return n + 1;
    }
    int main () { 
    	int n;
    	while(cin >>n) {
    		MyInt objInt(n); 
    		objInt-2-1-3; 
    		cout << Inc(objInt);
    		cout <<","; 
    		objInt-2-1; 
    		cout << Inc(objInt) << endl;
    	}
    	return 0;
    }

이 문제는 주로 연산자의 재부팅을 고찰하는데 이 안에서 비교적 어려운 점은 연산자'-'의 연속 연산이고 또 다른 하나는 함수 대체형이 인삼을 때 어떻게 MyInt 유형을 int 유형으로 전환해야 하는지이다.첫 번째 점을 보고 우리는 먼저'-'라는 연산자를 다시 불러왔다. 연속적으로 연산할 수 있도록 우리는 유형이 반드시 MyInt의 인용 클래스가 되어야 매번 연산할 때objInt이라는 대상이'-'에 연산될 수 있음을 보장할 수 있다.위 코드:
MyInt & operator-(int n) {
        this->nVal = this->nVal - n;
        return *this;
    }

주:*this 바늘은 이 대상 자체를 되돌려 주는 인용을 가리킨다.
두 번째 문제, 이것은 작은 구덩이라고 할 수 있다. 제목에서objInt이라는 대상을 Inc 함수에 직접 넣고 강한 변화를 숨긴다. n=(int)objInt;그래서 우리는 이 연산자를 다시 불러와야 한다. 다시 불러오는 연산자의 규칙에 따라.
operator int () {
        
        return nVal;
    }

문제가 해결되었습니다~
부족한 점이 있으면 지적해 주십시오!

좋은 웹페이지 즐겨찾기