Bruke navneområder i VB.NET

Den vanligste måten VB.NET-navneområder brukes av de fleste programmerere er å fortelle kompilatoren hvilke .NET Framework biblioteker som er nødvendige for et bestemt program. Når du velger en "mal" for prosjektet ditt (for eksempel "Windows Forms Application"), er en av tingene at du velger er det spesifikke settet med navnefelt som det automatisk blir henvist til i ditt prosjekt. Dette gjør koden i disse navneområdene tilgjengelige for programmet ditt.

For eksempel er noen av navnefeltene og de faktiske filene de har i en Windows Forms-applikasjon:

System> i System.dll
System. Data> i system. Data.dll
System. Distribusjon> System. Deployment.dll
System. Tegning> System. Drawing.dll
System. Windows. Skjemaer> System. Windows. Forms.dll

Du kan se (og endre) navnefelt og referanser for prosjektet ditt i prosjektegenskapene under referanser fane.

Denne måten å tenke på navneområder gjør at de ser ut til å være de samme tingene som "kodebibliotek", men det er bare en del av ideen. Den virkelige fordelen med navneområder er organisering.

instagram viewer

De fleste av oss vil ikke få sjansen til å etablere et nytt navneromhierarki fordi det vanligvis bare gjøres en gang i begynnelsen for et stort og komplisert kodebibliotek. Men her lærer du hvordan du tolker navnene som du vil bli bedt om å bruke i mange organisasjoner.

Hva navnerom gjør

Navnearealer gjør det mulig å organisere titusenvis av. NET Framework-objekter og alle objektene som VB-programmerere lager også i prosjekter, slik at de ikke blir sammenstøt.

Hvis du for eksempel søker på .NET etter en Farge objekt, finner du to. Det er en Farge objekt i begge:

System. Tegning
System. Windows. Media

Hvis du legger til en import uttalelse for begge navnefeltene (en referanse kan også være nødvendig for prosjektegenskapene) ...

Importsystem. Tegning
Importsystem. Windows. Media

... så en uttalelse som ...

Dim en som farge

... vil bli markert som en feil med notatet "Farge er tvetydig" og .NET vil påpeke at begge navnefeltene inneholder et objekt med det navnet. Denne typen feil kalles en "navnekollisjon."

Dette er den virkelige grunnen til "navneområder", og det er også måten navneområder brukes i andre teknologier (for eksempel XML). Navnearealer gjør det mulig å bruke samme objektnavn, som Farge, når navnet passer og fortsatt holder ting organisert. Du kan definere en Farge objekt i din egen kode og hold den forskjellig fra kodene i .NET (eller koden til andre programmerere).

Navneområde MyColor
Offentlig klasse farge
Underfarge ()
' Gjør noe
Slutt sub
Sluttklasse
Slutt navneområde

Du kan også bruke Farge objekt et annet sted i programmet slik:

Dim c Som ny MyColor. Farge
c. Farge()

Før du går inn på noen av de andre funksjonene, må du være oppmerksom på at hvert prosjekt er inne i et navneområde. VB.NET bruker navnet på prosjektet ditt (WindowsApplication1 for et standardskjema-program hvis du ikke endrer det) som standard navneområde. For å se dette, opprett et nytt prosjekt (vi brukte navnet NSProj og sjekk Object Browser-verktøyet):

  1. Klikk Her for å vise illustrasjonen
  2. Klikk på Tilbake -knappen i nettleseren for å gå tilbake

Objektleseren viser det nye prosjektnavnområdet (og de automatisk definerte objektene i det) rett sammen med .NET Framework navnefelt. Denne muligheten til VB.NET å gjøre objektene dine lik. NET-objekter er en av nøklene til kraften og fleksibiliteten. For eksempel er det grunnen til at Intellisense vil vise dine egne objekter så snart du definerer dem.

La oss definere et nytt prosjekt for å sparke et hakk NewNSProj i samme løsning (bruk Fil > Legg til > Nytt prosjekt ...) og kode et nytt navneareal i det prosjektet. Og bare for å gjøre det morsommere, la oss legge det nye navnefeltet i en ny modul (vi kalte det NewNSMod). Og siden et objekt må kodes som en klasse, la vi også til en klasseblokk (navngitt NewNSObj). Her er koden og løsningsutforskeren for å vise hvordan den passer sammen:

  1. Klikk Her for å vise illustrasjonen
  2. Klikk på Tilbake -knappen i nettleseren for å gå tilbake

Siden din egen kode er "akkurat som Rammekode", er det nødvendig å legge til en referanse til NewNSMod i NSProj å bruke objektet i navnefeltet, selv om de er i samme løsning. Når det er gjort, kan du erklære et objekt i NSProj basert på metoden i NewNSMod. Du må også "bygge" prosjektet slik at et faktisk objekt eksisterer til referanse.

Dim o As New NewNSProj. AVBNS.NewNSMod. NewNSObj
o. AVBNSMethod ()

Det er ganske Dim uttalelse skjønt. Vi kan forkorte det ved å bruke en import uttalelse med et alias.

Import NS = NewNSProj. AVBNS.NewNSMod. NewNSObj
...
Dim o Som ny NS
o. AVBNSMethod ()

Ved å klikke på Kjør-knappen vises MsgBox fra navneområdet AVBNS, "Hei! Det funket!"

Når og hvorfor du bruker navneområder

Alt så langt har egentlig bare vært syntaks - den koding regler som du må følge i ved å bruke navnefelt. Men for å dra fordel, trenger du to ting:

  • Et krav for organisering av navneområdet i utgangspunktet. Du trenger mer enn bare et "Hello World" -prosjekt før organisering av navnefelt begynner å lønne seg.
  • En plan for å bruke dem.

Generelt, Microsoft anbefaler at du organiserer organisasjonens kode ved å bruke en kombinasjon av firmanavnet med produktnavnet.

Så hvis du for eksempel er programvarearkitekt for Dr. No's Nose Knows Plastic Surgery, kan det være lurt å organisere navnene dine som ...

DRNo
rådgivning
ReadTheirWatchNChargeEm
TellEmNuthin
Kirurgi
ElephantMan
MyEyeLidsRGone

Dette ligner på .NETs organisasjon ...

Gjenstand
System
Kjerne
IO
Linq
Data
ODBC
sql

Navnområdene på flere nivåer oppnås ved å bare hekke navneområdeblokkene.

Navneområde DRNo
Navneområdeoperasjon
Navneområde MyEyeLidsRGone
'VB-kode
Slutt navneområde
Slutt navneområde
Slutt navneområde

eller

Navneområde DRNo. Kirurgi. MyEyeLidsRGone
'VB-kode
Slutt navneområde