Fortran - wskaźniki

W większości języków programowania zmienna wskaźnikowa przechowuje adres pamięci obiektu. Jednak w Fortranie wskaźnik jest obiektem danych, który ma więcej funkcji niż tylko przechowywanie adresu pamięci. Zawiera więcej informacji o określonym obiekcie, takich jak typ, ranga, zakres i adres pamięci.

Wskaźnik jest powiązany z celem przez alokację lub przypisanie wskaźnika.

Deklarowanie zmiennej wskaźnika

Zmienna wskaźnika jest deklarowana za pomocą atrybutu wskaźnika.

Poniższe przykłady pokazują deklarację zmiennych wskaźnikowych -

integer, pointer :: p1 ! pointer to integer  
real, pointer, dimension (:) :: pra ! pointer to 1-dim real array  
real, pointer, dimension (:,:) :: pra2 ! pointer to 2-dim real array

Wskaźnik może wskazywać na -

  • Obszar dynamicznie przydzielanej pamięci.

  • Obiekt danych tego samego typu co wskaźnik, z rozszerzeniem target atrybut.

Przydzielanie miejsca na wskaźnik

Plik allocateinstrukcja umożliwia przydzielenie miejsca na obiekt wskaźnika. Na przykład -

program pointerExample
implicit none

   integer, pointer :: p1
   allocate(p1)
   
   p1 = 1
   Print *, p1
   
   p1 = p1 + 4
   Print *, p1
   
end program pointerExample

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

1
5

Należy opróżnić przydzieloną przestrzeń dyskową przez rozszerzenie deallocate oświadczenie, gdy nie jest już potrzebne i uniknąć gromadzenia niewykorzystanego i bezużytecznego miejsca w pamięci.

Cele i skojarzenie

Cel to kolejna normalna zmienna, na którą jest zarezerwowana przestrzeń. Zmienną docelową należy zadeklarować z rozszerzeniemtarget atrybut.

Możesz powiązać zmienną wskaźnikową ze zmienną docelową za pomocą operatora asocjacji (=>).

Przepiszmy poprzedni przykład, aby zademonstrować koncepcję -

program pointerExample
implicit none

   integer, pointer :: p1
   integer, target :: t1 
   
   p1=>t1
   p1 = 1
   
   Print *, p1
   Print *, t1
   
   p1 = p1 + 4
   
   Print *, p1
   Print *, t1
   
   t1 = 8
   
   Print *, p1
   Print *, t1
   
end program pointerExample

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

1
1
5
5
8
8

Wskaźnik może być -

  • Undefined
  • Associated
  • Disassociated

W powyższym programie mamy associatedwskaźnik p1 z docelowym t1, używając operatora =>. Powiązana funkcja testuje stan asocjacji wskaźnika.

Plik nullify instrukcja odłącza wskaźnik od celu.

Nullify nie opróżnia celów, ponieważ może istnieć więcej niż jeden wskaźnik wskazujący na ten sam cel. Jednak opróżnienie wskaźnika oznacza również unieważnienie.

Przykład 1

Poniższy przykład ilustruje koncepcje -

program pointerExample
implicit none

   integer, pointer :: p1
   integer, target :: t1 
   integer, target :: t2
   
   p1=>t1
   p1 = 1
   
   Print *, p1
   Print *, t1
   
   p1 = p1 + 4
   Print *, p1
   Print *, t1
   
   t1 = 8
   Print *, p1
   Print *, t1
   
   nullify(p1)
   Print *, t1
   
   p1=>t2
   Print *, associated(p1)
   Print*, associated(p1, t1)
   Print*, associated(p1, t2)
   
   !what is the value of p1 at present
   Print *, p1
   Print *, t2
   
   p1 = 10
   Print *, p1
   Print *, t2
   
end program pointerExample

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

1
1
5
5
8
8
8
T
F
T
0
0
10
10

Pamiętaj, że za każdym razem, gdy uruchomisz kod, adresy pamięci będą inne.

Przykład 2

program pointerExample
implicit none

   integer, pointer :: a, b
   integer, target :: t
   integer :: n
   
   t = 1
   a => t
   t = 2
   b => t
   n = a + b
   
   Print *, a, b, t, n 
   
end program pointerExample

Kiedy powyższy kod jest kompilowany i wykonywany, daje następujący wynik -

2  2  2  4