Selv om pekere ikke er like viktige i Delphi som de er i C eller C ++, de er et så "grunnleggende" verktøy som nesten hva som helst å gjøre med programmering må takle pekere på en eller annen måte.
Det er av den grunnen at du kan lese om hvordan en streng eller objekt egentlig bare er en peker, eller at en hendelsesbehandler som OnClick, faktisk er en peker til en prosedyre.
Peker til datatype
Enkelt sagt er en peker en variabel som holder adressen til hva som helst i minnet.
For å konkretisere denne definisjonen, må du huske at alt som brukes av et program, er lagret et sted i datamaskinens minne. Fordi en peker har adressen til en annen variabel, sies den å peke på den variabelen.
Mesteparten av tiden peker poeng i Delphi til en bestemt type:
Var
iValue, j: heltall; pIntValue: ^ heltall;
begynneiValue: = 2001; pIntValue: = @iValue;... j: = pIntValue ^;
slutt;
De syntaks å erklære en peker datatype bruker a caret (^). I ovennevnte kode er iValue en variabel med heltallstype og pIntValue er en peker av heltallstype. Siden en peker ikke er mer enn en adresse i minnet, må vi tildele den plasseringen (adressen) til verdien som er lagret i iValue-heltalvariabelen.
De @ operatør returnerer adressen til en variabel (eller en funksjon eller prosedyre som vil bli vist nedenfor). Tilsvarende med @ -operatøren er Addr-funksjon. Vær oppmerksom på at pIntValues verdi ikke er 2001.
I denne eksempelskoden er pIntValue en skrevet heltallspeker. God programmeringsstil er å bruke skrevne pekere så mye du kan. Pekerdatatypen er en generisk pekertype; det representerer en peker til alle data.
Merk at når "^" vises etter en pekervariabel, henviser den til pekeren; det vil si at den returnerer verdien som er lagret på minneadressen som holdes av pekeren. I dette eksemplet har variabel j samme verdi som iValue. Det kan se ut som om dette ikke har noen hensikt når vi ganske enkelt kan tildele iValue til j, men dette kodestykket ligger bak de fleste anrop til Win API.
NILing-pekere
Ikke-tildelte pekere er farlige. Siden pekere lar oss jobbe direkte med datamaskinens minne, kan vi få en feil ved tilgang til brudd hvis vi prøver (ved en feiltakelse) å skrive til et beskyttet sted i minnet. Dette er grunnen til at vi alltid bør initialisere en peker til NIL.
NIL er en spesiell konstant som kan tilordnes hvilken som helst peker. Når null er tilordnet en peker, refererer ikke pekeren til noe. Delphi presenterer for eksempel en tom dynamisk matrise eller en lang streng som en nullpeker.
Karakterpekere
De grunnleggende typene PAnsiChar og PWideChar representerer peker til AnsiChar og WideChar verdier. Den generiske PChar representerer en peker til en Char-variabel.
Disse tegnpekene brukes til å manipulere nullopphørte strenger. Tenk på en PChar som en peker til en null-avsluttet streng eller til matrisen som representerer en.
Pekere til poster
Når vi definerer en post eller annen datatype, er det en vanlig praksis også å definere en peker til den typen. Dette gjør det enkelt å manipulere forekomster av typen uten å kopiere store blokker med minne.
Evnen til å ha pekepinner til poster (og matriser) gjør det mye enklere å sette opp kompliserte datastrukturer som koblede lister og trær.
type
pNextItem = ^ TLinkedListItem
TLinkedListItem = ta oppsName: String; iValue: Heltall; NextItem: pNextItem;
slutt;
Tanken bak koblede lister er å gi oss muligheten til å lagre adressen til neste koblede element i en liste i et NextItem-postfelt.
Pekere til poster kan også brukes når du lagrer tilpassede data for hvert trevisningselement, for eksempel.
Prosedyre- og metodepekere
Et annet viktig pekerkonsept i Delphi er prosedyre- og metodepekere.
Pekere som peker på adressen til en prosedyre eller funksjon kalles prosedyrepekere. Metodepekere ligner prosedyrepekere. I stedet for å peke på frittstående prosedyrer, må de imidlertid peke på klassemetoder.
Metodepekeren er en peker som inneholder informasjon om både navnet og objektet som blir påberopt.
Pekere og Windows API
Den vanligste bruken for pekere i Delphi er grensesnitt til C- og C ++ -kode, som inkluderer tilgang til Windows API.
Windows API-funksjoner bruker en rekke datatyper som kan være ukjente for Delphi-programmereren. De fleste av parameterne i å ringe API-funksjoner er pekere på en viss datatype. Som nevnt ovenfor, bruker vi null-avsluttede strenger i Delphi når vi kaller Windows API-funksjoner.
I mange tilfeller, når et API-anrop returnerer en verdi i en buffer eller peker til en datastruktur, må disse buffere og datastrukturer tildeles av applikasjonen før API-anropet blir utført. SHBrowseForFolder Windows API-funksjonen er ett eksempel.
Pekeren og minnetildeling
Pekepinners virkelige kraft kommer fra muligheten til å sette av minne mens programmet kjøres.
Denne koden skal være nok til å bevise at det ikke er så vanskelig å jobbe med pekere som det kan se ut til å begynne med. Den brukes til å endre teksten (bildeteksten) til kontrollen med det medfølgende håndtaket.
fremgangsmåte GetTextFromHandle (hWND: THandle);
Var pTekst: PChar; // en peker til røye (se over)TextLen: heltall;
begynne
{få lengden på teksten}TextLen: = GetWindowTextLength (hWND);
{tilordne minne}
GetMem (pText, TextLen); // tar en peker
{få kontrollens tekst}GetWindowText (hWND, pText, TextLen + 1);
{vis teksten}ShowMessage (String (pText))
{frigjør minnet}FreeMem (pText);
slutt;