PDA

View Full Version : سوال: operator



ehsanshm
یک شنبه 05 مهر 1388, 21:20 عصر
سلام سوال من اینکه که چرا در کنار تعریف بعضی از operatorها علامت & می گزارند؟
مثلا

(myclass &operator+(myclass ob

deopen
یک شنبه 05 مهر 1388, 23:52 عصر
یکی از روش های ارجاع قرار دادن متغیر در کلاس برگرداندن یک ارجاع به متغیر است , به مثال زیر توجه کنید :


#include<iostream>
using std::cout;
using std::cin;

#include<windows.h>


class test {
public:
int &ref(){
return number;
}
void print() {
cout<<number<<"\n";
}

private:
int number;
};

int main()
{
test tst;
tst.ref()=5;
tst.print();


system("pause");
return 0;
}

خوب از این روش برای operator overloading استفاده میشه , برای مثال در کد زیر عملگر [] طوری overload شده که عنصر خاصی از خودش را مورد ارجاع قرار بده , حال در مثال زیر فرق بین برگرداندن ارجاع و برگرداندن مقدار را متوجه خواهید شد , من برای مثال زیر بهتر دونستم که کل کد را ضمیمه کنم تا از خطاهای احتمالی جولوگیری شود, پس از حجم زیاد کد نترسید و قسمتهای blod شده را مشاهده کنید:


#include <iostream>
using std::cerr;
using std::cout;
using std::cin;
using std::endl;

#include <iomanip>
using std::setw;

#include <cstdlib> // exit function prototype
using std::exit;

#include "Array.h" // Array class definition

// default constructor for class Array (default size 10)
Array::Array( int i,int j ):
i(i),j(j)
{
if (i>0 && j>0)
size=i*j;
// validate arraySize
ptr = new int[ size ]; // create space for pointer-based array

for ( int i = 0; i < size; i++ )
ptr[ i ] = 0; // set pointer-based array element
} // end Array default constructor


// copy constructor for class Array;
// must receive a reference to prevent infinite recursion
Array::Array( const Array &arrayToCopy )
: size( arrayToCopy.size )
{
ptr = new int[ size ]; // create space for pointer-based array

for ( int i = 0; i < size; i++ )
ptr[ i ] = arrayToCopy.ptr[ i ]; // copy into object
} // end Array copy constructor

// destructor for class Array
Array::~Array()
{
delete [] ptr; // release pointer-based array space
} // end destructor

// return number of elements of Array
int Array::getSize() const
{
return size; // number of elements in Array
} // end function getSize

// overloaded assignment operator;
// const return avoids: ( a1 = a2 ) = a3
const Array &Array::operator=( const Array &right )
{
if ( &right != this ) // avoid self-assignment
{
// for Arrays of different sizes, deallocate original
// left-side array, then allocate new left-side array
if ( size != right.size )
{
delete [] ptr; // release space
size = right.size;
i=right.i;
j=right.j;// resize this object

ptr = new int[ size ]; // create space for array copy
} // end inner if

for ( int i = 0; i < size; i++ )
ptr[ i ] = right.ptr[ i ]; // copy array into object
} // end outer if

return *this; // enables x = y = z, for example
} // end function operator=

// determine if two Arrays are equal and
// return true, otherwise return false
bool Array::operator==( const Array &right ) const
{
if ( size != right.size || i != right.i || j != right.j )
return false; // arrays of different number of elements

for ( int i = 0; i < size; i++ )
if ( ptr[ i ] != right.ptr[ i ] )
return false; // Array contents are not equal

return true; // Arrays are equal
} // end function operator==

// overloaded subscript operator for non-const Arrays;
// reference return creates a modifiable lvalue
int &Array::operator[]( int subscript )
{
// check for subscript out-of-range error
if ( subscript < 0 || subscript >= size )
{
cerr << "\nError: Subscript " << subscript
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ subscript ]; // reference return
} // end function operator[]

// overloaded subscript operator for const Arrays
// const reference return creates an rvalue
int Array::operator[]( int subscript)const
{
// check for subscript out-of-range error
if ( subscript < 0 || subscript >= size )
{
cerr << "\nError: Subscript " << subscript
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ subscript ]; // returns copy of this element
} // end function operator[]

int &Array::operator()( int index) {

if ( index < 0 || index >= size )
{
cerr << "\nError: Subscript " << index
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ index ];
}

int Array::operator()( int index) const {

if ( index < 0 || index >= size )
{
cerr << "\nError: Subscript " << index
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ index ];
}

int &Array::operator()( int index,int index2) {

if ( index < 0 || index2 < 0 || (index*index2) >= size || index > i || index2 > j)
{
cerr << "\nError: Subscript " << index<< "," << index2
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ (index*index2) ];
}

int Array::operator()( int index,int index2)const {

if ( index < 0 || index2 < 0 || (index*index2) >= size || index > i || index2 > j)
{
cerr << "\nError: Subscript " << index << "," << index2
<< " out of range" << endl;
exit( 1 ); // terminate program; subscript out of range
} // end if

return ptr[ (index*index2) ];
}

// overloaded input operator for class Array;
// inputs values for entire Array

void Array::renew(int newI,int newJ) {

if (newI!=i && newJ!=j) {
int *cpy=0;
cpy=new int[size];
for (int i=0;i<size;i++)
cpy[i]=ptr[i];
delete [] ptr; // release space
int lastSize=size;
size = newI*newJ;
bool sze;
if (size>lastSize)
sze=true;
else
sze=false;

Array::i=newI;
Array::j=newJ;// resize this object

ptr = new int[ size ];

for (int i=0;i<(sze?lastSize:size);i++)
ptr[i]=cpy[i];
if(sze) {
for (int i=lastSize;i<size;i++)
ptr[i]=0;
}

delete [] cpy;
}

}

void Array::renew(int newI) {

if (newI!=i) {
int *cpy=0;
cpy=new int[size];// release space
for (int i=0;i<size;i++)
cpy[i]=ptr[i];
delete [] ptr;
int lastSize=size;
size = newI;
bool sze;
if (size>lastSize)
sze=true;
else
sze=false;

Array::i=newI;

ptr = new int[ size ];

for (int i=0;i<(sze?lastSize:size);i++)
ptr[i]=cpy[i];
if(sze) {
for (int i=lastSize;i<size;i++)
ptr[i]=0;
}

delete [] cpy;
}

}

#include<conio.h>



int main()
{
Array Arr(4,2);

Arr(2,1)=1;

Arr.renew(6,4);

cout<<Arr(2,1);

getch();

return 0;
} // end main


کد بالا بسط کلاس array می باشد در کد توجه داشته باشید که کد قرمز از عملگر overload شده با ارجاع استفاده میکند و کد آبی از تابع همشکل خودش اما بدون ارجاع استفاده میکند.