ehsanshm
یک شنبه 05 مهر 1388, 22:20 عصر
سلام سوال من اینکه که چرا در کنار تعریف بعضی از operatorها علامت & می گزارند؟
مثلا
(myclass &operator+(myclass ob
deopen
دوشنبه 06 مهر 1388, 00: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 شده با ارجاع استفاده میکند و کد آبی از تابع همشکل خودش اما بدون ارجاع استفاده میکند.
vBulletin® v4.2.5, Copyright ©2000-1403, Jelsoft Enterprises Ltd.