다음을 통해 공유


포인터

포인터가 다음과 같은 시퀀스를 사용 하 여 선언 됩니다.

[storage-class-specifiers] [cv-qualifiers] type-specifiers 
[ms-modifier] declarator ;

여기서 모든 유효한 포인터 선언 자를 사용할 수 있습니다 declarator.간단한 포인터 선언 자 구문은 다음과 같습니다.

* [cv-qualifiers] identifier [= expression]

1.선언 지정자:

  • 선택적 저장소 클래스 지정 자가 있습니다.자세한 내용은 지정자.

  • 선택적인 const 또는 volatile 를 가리키는 개체의 형식에 적용 되는 키워드입니다.

  • 형식 지정자:를 가리키는 개체의 형식을 나타내는 형식의 이름입니다.

2.선언 자:

  • 선택적 Microsoft 특정 한정자입니다.자세한 내용은 Microsoft 전용 한정자.

  • * 연산자입니다.

  • 선택적인 const 또는 volatile 포인터에 적용 되는 키워드입니다.

  • 식별자입니다.

  • 선택적 이니셜라이저입니다.

함수의 포인터에 대 한 선언 자를 다음과 같이 나타납니다.

(* [cv-qualifiers] identifier )( argument-list ) [cv-qualifers]
[exception specification] [= expression];
  • 구문에 대 한 포인터의 배열에 다음과 같이 나타납니다.
* identifier [ [ constant-expression ] ]
  • 그러나 포인터 선언 자 좀 더 복잡 한 될 수 있습니다.자세한 내용은 선언 자.

  • 함께 선언 자를 여러 개 및 해당 이니셜라이저가 단일 선언에서는 선언 지정자를 다음 쉼표로 구분 된 목록에에서 나타날 수 있습니다.

포인터 선언 하는 간단한 예제가입니다.

char *pch;

앞의 선언에서는 지정 pch 유형의 개체를 가리키는 char.

더 복잡 한 예제가입니다.

static unsigned int * const ptr;

앞의 선언에서는 지정 ptr 형식의 개체에 대 한 상수 포인터입니다 unsignedint 정적 저장소 기간이 있습니다. 

다음 예제에서는 어떻게 여러 포인터를 선언 하 고 초기화를 보여 줍니다.

static int *p = &i, *q = &j;

앞의 예제에서 포인터 p와 q 형식의 개체를 가리키고 int 및 i와 j의 주소를 각각 초기화 됩니다.저장소 클래스 지정자 static 두 포인터에만 적용 됩니다.

예제

// pointer.cpp
// compile with: /EHsc
#include <iostream>
int main() {
   int i = 1, j = 2; // local variables on the stack
   int *p;

   // a pointer may be assigned to "point to" the value of
   // another variable using the & (address of) operator
   p = & j; 

   // since j was on the stack, this address will be somewhere
   // on the stack.  Pointers are printed in hex format using
   // %p and conventionally marked with 0x.  
   printf_s("0x%p\n",  p);

   // The * (indirection operator) can be read as "the value
   // pointed to by".
   // Since p is pointing to j, this should print "2"
   printf_s("0x%p %d\n",  p, *p);

   // changing j will change the result of the indirection
   // operator on p.
   j = 7;
   printf_s("0x%p %d\n",  p, *p );

   // The value of j can also be changed through the pointer
   // by making an assignment to the dereferenced pointer
   *p = 10;
   printf_s("j is %d\n", j); // j is now 10

   // allocate memory on the heap for an integer,
   // initialize to 5
   p = new int(5);

   // print the pointer and the object pointed to
   // the address will be somewhere on the heap
   printf_s("0x%p %d\n",  p, *p);

   // free the memory pointed to by p
   delete p;

   // At this point, dereferencing p with *p would trigger
   // a runtime access violation.

   // Pointer arithmetic may be done with an array declared
   // on the stack or allocated on the heap with new.
   // The increment operator takes into account the size 
   // of the objects pointed to.
   p = new int[5];
   for (i = 0; i < 5; i++, p++) {
      *p = i * 10;
      printf_s("0x%p %d\n", p, *p);
   }

   // A common expression seen is dereferencing in combination
   // with increment or decrement operators, as shown here.
   // The indirection operator * takes precedence over the 
   // increment operator ++. 
   // These are particularly useful in manipulating char arrays.
   char s1[4] = "cat";
   char s2[4] = "dog";
   char* p1 = s1;
   char* p2 = s2;

   // the following is a string copy operation
   while (*p1++ = *p2++);

   // s2 was copied into s1, so now they are both equal to "dog"
   printf_s("%s %s", s1, s2);
}
  

또 다른 예로 데이터 구조에서 포인터를 보여 줍니다. 이 경우에 연결 된 목록에 있습니다.

// pointer_linkedlist.cpp
// compile with: /EHsc
#include <iostream>
using namespace std;

struct NewNode {
   NewNode() : node(0){}
   int i;
   NewNode * node;
};

void WalkList(NewNode * ptr) {
   if (ptr != 0) {
      int i = 1;
      while (ptr->node != 0 ) {
         cout << "node " << i++ << " = " << ptr->i << endl;
         ptr = ptr->node;
      }
      cout << "node " << i++ << " = " << ptr->i << endl;
   }
}

void AddNode(NewNode ** ptr) {
   NewNode * walker = 0;
   NewNode * MyNewNode = new NewNode;
   cout << "enter a number: " << endl;
   cin >> MyNewNode->i;

   if (*ptr == 0)
      *ptr = MyNewNode;
   else  {
      walker = *ptr;
      while (walker->node != 0)
         walker = walker->node;

      walker->node = MyNewNode;
   }
}

int main() {
   char ans = ' ';
   NewNode * ptr = 0;
   do {
      cout << "a (add node)  d (display list)  q (quit)" << endl;
      cin >> ans;
      switch (ans) {
      case 'a':
         AddNode(&ptr);
         break;
      case 'd':
         WalkList(ptr);
         break;
      }
   } while (ans != 'q');
}
  

참고 항목

참조

C + + 추상 선언 자

포인터 형식 추가

간접 참조 연산자: *

주소 연산자: &