logo

Простір імен у C ++ | Встановіть 3 (доступ, створення заголовка, гніздування та псевдоніму)

Простір імен у C ++ | Набір 1 (Вступ) Простір імен у C ++ | Встановіть 2 (розширення простору імен та безіменного простору імен)

Різні способи доступу до простору імен: У C ++ існує два способи доступу змінних та функцій простору імен.



Визначення простору імен:

Визначення простору імен починається з простору імен ключових слів, а потім ім'ям простору імен:

namespace  namespace_name   
{
// code declarations i.e. variable  (int a;)
method (void add();)
classes ( class student{};)
}

Слід зазначити, що після заключної дужки немає крапки з комою (;).
Щоб викликати версію з підтримкою простору або функції або змінної підготовки імені простору імен наступним чином:
імена імені_name :: код;  // Код може бути змінною функцією або класом.



Директива використання:

Ви також можете уникнути готовності простору імен за допомогою Директиви про простір імен. Ця директива повідомляє компілятору, що наступний код використовує імена у вказаному просторі імен. 
Таким чином, простір імен має на увазі наступний код:

C++
#include    using namespace std; // first name space namespace first_space {  void func()  {  cout << 'Inside first_space' << endl;  } } // second name space namespace second_space {  void func()  {  cout << 'Inside second_space' << endl;  } } using namespace first_space; int main () {  // This calls function from first name space.  func();  return 0; } 

Імена, введені в застосуванні Директиви, дотримуючись нормальних правил обсягу. Назва видно з точки використання Директиви до кінця області, в якій знайдена Директива. Суб'єкти з однойменною назвою, визначеними у зовнішньому обсязі, приховані.



Вкладені простори імен:

прокручування мишею не працює

Простір імен можна вкладати там, де можна визначити один простір імен всередині іншого простору імені наступним чином:

namespace namespace_name1   
{
  // code declarations
  namespace namespace_name2 
  {
     // code declarations
  }
}

Ви можете отримати доступ до членів вкладеного простору імен, використовуючи оператори роздільної здатності наступним чином:
// для доступу до членів імені_name2
Використання простору імен імені_name1 :: namespace_name2;
// для доступу до членів простору імен: name1
Використання простору імен імені_name1;


У наведених вище твердженнях, якщо ви використовуєте namesspace_name1, то це зробить елементи імені amespace_name2 в області наступним чином:

C++
#include    using namespace std; // first name space namespace first_space {  void func()  {  cout << 'Inside first_space' << endl;  }  // second name space  namespace second_space  {  void func()  {  cout << 'Inside second_space' << endl;  }  } } using namespace first_space::second_space; int main () {  // This calls function from second name space.  func();    return 0; } 

1. Нормальний спосіб  

CPP
// C++ program to demonstrate accessing of variables // in normal way i.e. using '::' #include    using namespace std; namespace geek {  int rel = 300;  } int main() {  // variable ‘rel’ accessed   // using scope resolution operator  cout &lt;&lt; geek::rel &lt;&lt; &quot;n&quot;; // prints 300  return 0; } 

Вихід:

300  

2. "Використання" Директиви  

CPP
// C++ program to demonstrate accessing of variables // in normal way i.e. using 'using' directive #include    using namespace std; namespace geek {  int rel = 300;  } // use of ‘using’ directive using namespace geek; int main() {  // variable ‘rel’ accessed   // without using scope resolution variable  cout &lt;&lt; rel &lt;&lt; &quot;n&quot;; //prints 300    return 0; } 

Вихід:

300  

Використання простору імен у файлах заголовків Ми можемо створити простір імен в одному файлі та вміст доступу за допомогою іншої програми. Це робиться наступним чином.

  • Нам потрібно створити два файли. Один із них, що містить простір імен та всі члени даних та функції членів, які ми хочемо використовувати пізніше.
  • А інша програма може безпосередньо зателефонувати в першу програму, щоб використовувати всі члени даних та функції членів у ній.

Файл 1  

CPP
// file1.h  namespace foo {  int value()   {   return 5;   } } 

Файл 2  

CPP
// file2.cpp - Not to be executed online #include    #include file1.h // Including file1 using namespace std; int main ()  {  cout &lt;&lt; foo::value();  return 0; } 

Тут ми можемо побачити, що простір імен створюється у файлі1.h, а значення () цього простору імен викликається у файлі2.cpp. Вкладені простори імен У просторах імен C ++ також можна ввести, тобто один простір імен всередині іншого. Резолюція змінних простору імен є ієрархічною. 

CPP
// C++ program to demonstrate nesting of namespaces #include    using namespace std; // Nested namespace namespace out {  int val = 5;   namespace in  {  int val2 = val;   } } // Driver code int main() {  cout &lt;&lt; out::in::val2; // prints 5  return 0; } 

Вихід:

5  

Псевдонім простору імен: У C ++ ви можете використовувати ім'я псевдоніму для імені простору імен для зручності використання. Існуючі простори імен можуть бути оселі з новими іменами з наступним синтаксисом:

метод дорівнює в java
namespace new_name = current_name;  
CPP
#include    namespace name1  {  namespace name2   {  namespace name3   {  int var = 42;  }  } } // Aliasing  namespace alias = name1::name2::name3;   int main() {  std::cout &lt;&lt; alias::var &lt;&lt; 'n'; } 

Вихід:

42  

Якщо вам подобаються HeksForgeeks і хочете внести свій внесок, ви також можете написати статтю за допомогою prite.geeksforgeeks.org або надішліть свою статтю на огляд [email protected]. Дивіться свою статтю, що з’являється на головній сторінці GeksForgeeks та допоможіть іншим вундеркіндам.