Can anyone explain the logic behind the working of defined function in this program. This gives the correct output in this case even after commenting the whole logic of function.
#include <iostream>
using namespace std;
void swap(int *a, int *b)
{ /*
int temp=0;
temp= *a;
*a= *b;
*b=temp;
*/
}
int main()
{
int x, y;
cout << "This program is the demo of function call by pointer \n\n";
cout << "Enter the value of x & y \n";
cout << "x: ";
cin >> x;
cout << "y: ";
cin >> y;
cout << "Value befor swap " << endl;
cout << "x= " << x << " y= " << y << endl;
swap(x, y);
cout << "Value after swap " << endl;
cout << "x= " << x << " y= " << y << endl;
return 0;
}
That's why you shouldn't do
using namespace std;
, it just leads to confusion like this.What happens is that
std::swap
is called instead when you doswap(x, y);
.By the way, your swap won't work. It takes
int
pointers, but you give itint
. This wouldn't compile, you need to doswap(&x, &y);
instead. It only worked because it was always usingstd::swap
.swap
is ambiguous between your definition andstd::swap
. If you want to keep theusing namespace std
you need to encapsulate your method declaration in a class or a namespace and callYourNamespaceOrClass::swap(a, b)
explicitelyDeclaring
using namespace std;
means that you are using all the functions inside thenamespace std
. Now, in your code you have your own version ofswap
function which isvoid swap(int *a, int *b)
.The program worked fine in coincidence, because the
namespace std
has pre-defined function of swap() that accepts integers. Without this, your program will not work as your function created takes a pointer. That means, you need to pass the address of the variableswap(&var1, &var2)
.This is called Function Overloading. It finds the correct function that fits based on the parameters.
Hint: Avoid using
using namespace std;
as it will have problem(collisions) in bigger projects if you're not keen to your created functions.