Hjem Sosiale medier Hvordan å skjule instansvariabler i din iOS-app - dummies

Hvordan å skjule instansvariabler i din iOS-app - dummies

Video: Skjule steg i utregningen 2024

Video: Skjule steg i utregningen 2024
Anonim

Når egenskaper ble først utviklet for iOS app programmering, ble de sett på som en måte å unngå tidevannet for å skrive accessors for eksempel variabelbaserte egenskaper. Folk pleide å tenke på egenskaper som en måte å få tilgang til instansvariabler.

Faktisk bør forekomstvariabler ikke likestilles med egenskaper, og viktigere, forekomstvariabler skal ikke offentliggjøres. (Dette gjøres i strid med objektorienterte prinsippet om innkapsling, men det er en samtale for en annen tid.) Faktisk er Apples nye tilnærming å sette instansvariabeldeklarasjoner i implementeringsfilen til klassen.

Xcode 4. 2 kom til, programmerte de programmerte instansvariabler i headerfilen i @interface klassedeklarasjonen. I gamle tider ville du ha lagt til følgende dristige kode til TestDriveController. h-fil:

@interface TestDriveController: UIViewController { AVAudioPlayer * backgroundAudioPlayer; SystemSoundID burnRubberSoundID; BOOL touchInCar; }

Denne tilnærmingen gjorde forekomstvariabler (ivars) synlige for alle og alt og var i strid med prinsippet om innkapsling (selv om variablene ikke kunne nås).

Starter med Xcode 4. 2, kan du nå skjule instansvariabler ved å erklære dem i implementasjonsfilen på en av to måter. Den første er som en klasseutvidelse, som du oppretter ved å legge til et annet grensesnitt i implementeringsfilen etterfulgt av åpne og lukkede parenteser:

@interface TestDriveController () {AVAudioPlayer * backgroundAudioPlayer; SystemSoundID burnRubberSoundID; BOOL touchInCar;} -d

Den andre måten er å erklære instansvariabelen i @implementeringsblokken i klassen:

@implementation TestDriveController AVAudioPlayer * backgroundAudioPlayer; SystemSoundID burnRubberSoundID; BOOL touchInCar;

En klasseutvidelse er en variant av en Objective-C-kategori.

Tilnærmingen du bruker er ditt valg; Ved hjelp av klassetillegg gjør variablene lettere å skille mellom.

Du kan også bruke klasseutvidelser til å ha et offentligt deklarert sett med metoder og deretter erklære ytterligere metoder for bruk bare av klassen:

@interface TestDriveController () {AVAudioPlayer * backgroundAudioPlayer; SystemSoundID burnRubberSoundID; BOOL touchInCar;} - (void) privateMethod; -d

Disse metodene er egentlig ikke private, men er ikke synlige i headerfilen. De er "private APIer.“

Hvordan å skjule instansvariabler i din iOS-app - dummies

Redaktørens valg

Bruk skjermfeltet til å endre QuickBooks 2014 Rapporter - dummies

Bruk skjermfeltet til å endre QuickBooks 2014 Rapporter - dummies

Skjermbildet i QuickBooks Modify Report dialogboksen lar deg kontrollere rapportintervalldatoen, rapportgrunnlaget, kolonnene og en annen formatering. Bokstavene Rapporter datoområde - Datoer, Fra og Til - gjør det samme som Datoer, Fra og Til bokser i Rapportvinduet. Disse boksene lar ...

Bruk skjermfeltet til å modifisere QuickBooks 2013 Rapporter - dummies

Bruk skjermfeltet til å modifisere QuickBooks 2013 Rapporter - dummies

Hvis du klikker Tilpass rapport, QuickBooks viser dialogboksen Endre rapport, som du kan bruke til å tilpasse en rapport. Når du tilpasser en rapport, endrer du rapportens utseende, layout og informasjonen som den oppsummerer. Dialogboksen Endre rapport ser annerledes ut for ulike rapporttyper. Likevel, hvis du ser forbi ...

Bruk fanen Filtre til å modifisere QuickBooks 2014 Rapporter - dummies

Bruk fanen Filtre til å modifisere QuickBooks 2014 Rapporter - dummies

Filtrene kategorien er trolig den mest interessante og en nyttig kategori som er levert av dialogboksen QuickBooks Modify Report. Filtre-fanen lar deg sette opp filtre som du kan bruke til å angi hvilken informasjon som oppsummeres i rapporten. For å bruke Filtrer-fanen velger du først feltet du vil ha ...

Redaktørens valg

Administrere Cloud Computing Resources - dummies

Administrere Cloud Computing Resources - dummies

I teorien bør cloud computing-tjenester ikke være forskjellig fra ressursene i din eget miljø, bortsett fra at de bor eksternt. Ideelt sett har du en komplett visning av cloud computing-ressursene du bruker i dag, eller vil kanskje bruke i fremtiden. I de fleste skymiljøer kan kunden bare få tilgang til ...

Tips for Going Cloud med datanettverkene dine - dummies

Tips for Going Cloud med datanettverkene dine - dummies

Beregning med datanettverket ditt kan være, hva skal du gjøre for å ta nettverket ditt mot skyen? Her er noen anbefalinger: Ikke stole på en dårlig Internett-tilkobling. Først og fremst, før du tar noen av nettverksoperasjonene i skyen, gjør du ...

Nettverkstjenester levert gjennom Cloud Computing - dummies

Nettverkstjenester levert gjennom Cloud Computing - dummies

Tre forskjellige typer nettverkstjenester kan leveres via skyen: applikasjoner , plattformer og tjenester (infrastruktur). I de følgende avsnittene beskrives disse tre typer skyttjenester i større detalj. Programmer i skyen Vanligvis kalt Software as a Service (SaaS), fullt funksjonelle applikasjoner kan leveres via skyen. En av ...

Redaktørens valg

10 Hadoop Ressurser verdt en bokmerke - dummies

10 Hadoop Ressurser verdt en bokmerke - dummies

Følgende er ti fantastiske Hadoop-ressurser som er verdige til å skape en bokmerke i nettleseren din. Disse ressursene hjelper deg med å skape en livslang læringsplan for Hadoop. Sentralnervesystemet: Apache. org Apache Software Foundation (ASF) er det sentrale fellesskapet for open source-programvareprosjekter. Ikke bare et prosjekt kan være et Apache-prosjekt - ...

Data transformasjon i Hadoop - dummies

Data transformasjon i Hadoop - dummies

Ideen om Hadoop-inspirerte ETL motorer har fått mye trekkraft de siste årene. Hadoop er trods alt en fleksibel datalagrings- og behandlingsplattform som kan støtte store mengder data og operasjoner på dataene. Samtidig er det feiltolerant, og det gir mulighet for kapital- og programvarekostnad ...

Datablokker i Hadoop Distributed File System (HDFS) - dummier

Datablokker i Hadoop Distributed File System (HDFS) - dummier

Når du lagrer en fil i HDFS, bryter systemet det ned i et sett med individuelle blokker og lagrer disse blokkene i forskjellige slave noder i Hadoop-klyngen. Dette er en helt vanlig ting å gjøre, da alle filsystemer bryter filer ned i blokker før de lagres til disk. HDFS har ingen ...