In C++ is de scope-resolutieoperator :: . Het wordt gebruikt voor de volgende doeleinden.
1) Om toegang te krijgen tot een globale variabele wanneer er een lokale variabele met dezelfde naam is:
CPP
 // C++ program to show that we can access a global variable // using scope resolution operator :: when there is a local  // variable with same name  #include  using namespace std; int x; // Global x int main() { int x = 10; // Local x cout << 'Value of global x is ' << ::x; cout << '
Value of local x is ' << x;  return 0; }>   Uitvoer
Value of global x is 0 Value of local x is 10>
2) Om een functie buiten een klasse te definiëren.
CPP // C++ program to show that scope resolution operator :: is // used to define a function outside a class #include  using namespace std; class A { public:  // Only declaration  void fun(); }; // Definition outside class using :: void A::fun() { cout << 'fun() called'; } int main() {  A a;  a.fun();  return 0; }>   Uitvoer
fun() called>
3) Om toegang te krijgen tot de statische variabelen van een klasse.
CPP // C++ program to show that :: can be used to access static // members when there is a local variable with same name #include using namespace std; class Test {  static int x;  public:  static int y;   // Local parameter 'x' hides class member  // 'x', but we can access it using ::  void func(int x)   {   // We can access class's static variable  // even if there is a local variable  cout << 'Value of static x is ' << Test::x;  cout << '
Value of local x is ' << x;   } }; // In C++, static members must be explicitly defined  // like this int Test::x = 1; int Test::y = 2; int main() {  Test obj;  int x = 3 ;  obj.func(x);  cout << '
Test::y = ' << Test::y;  return 0; }>   Uitvoer
Value of static x is 1 Value of local x is 3 Test::y = 2>
4) In geval van meervoudige erfenis: Als dezelfde variabelenaam bestaat in twee voorouderklassen, kunnen we de scoperesolutie-operator gebruiken om onderscheid te maken.
CPP
 // Use of scope resolution operator in multiple inheritance. #include using namespace std; class A { protected:  int x; public:  A() { x = 10; } }; class B { protected:  int x; public:  B() { x = 20; } }; class C: public A, public B { public: void fun() {  cout << 'A's x is ' << A::x;  cout << '
B's x is ' << B::x; } }; int main() {  C c;  c.fun();  return 0; }>   Uitvoer
A's x is 10 B's x is 20>
5) Voor naamruimte Als er binnen twee naamruimten een klasse met dezelfde naam bestaat, kunnen we de naamruimtenaam gebruiken met de scope-resolutieoperator om zonder conflicten naar die klasse te verwijzen
C++ #include  #include  using namespace std; #define nline '
' // Global Declarations string name1 = 'GFG'; string favlang = 'python'; string companyName = 'GFG_2.0'; // You can also do the same thing in classes as we did in // our struct example class Developer { public:  string name = 'krishna';  string favLang = 'c++';  string company = 'GFG';  // Accessing Global Declarations  Developer(string favlang, string company)  : favLang(favlang)  , company(companyName)  {  } }; int main() {  Developer obj = Developer('python', 'GFG');  cout << 'favourite Language : ' << obj.favLang << endl;  cout << 'company Name : ' << obj.company << nline; }>   Uitvoer
favourite Language : python company Name : GFG_2.0>
6) Verwijs naar een klasse binnen een andere klasse: Als een klasse binnen een andere klasse bestaat, kunnen we de nestklasse gebruiken om naar de geneste klasse te verwijzen met behulp van de scope-resolutieoperator
CPP // Use of scope resolution class inside another class. #include  using namespace std; class outside { public:  int x;  class inside {  public:  int x;  static int y;  int foo();  }; }; int outside::inside::y = 5; int main() {  outside A;  outside::inside B; }>  7) Verwijs naar een lid van de basisklasse in het afgeleide object: In het geval dat we dezelfde methode hebben in zowel de basis- als de afgeleide klassen, kunnen we naar elke klasse verwijzen met de scope-resolutie-operator, zoals hieronder.
C++
 // Refer to a member of the base class in the derived object. #include  class Base { public:  void func()  {  std::cout << 'This is Base class' << std::endl;  } }; class Derived : public Base { public:  void func()  {  std::cout << 'This is Derived class' << std::endl;  } }; int main() {  Derived obj;  obj.Base::func();  obj.func();  return 0; }>   Uitvoer
This is Base class This is Derived class>
  
