Dela via


Regasm.exe (verktyget för sammansättningsregistrering)

Verktyget Sammansättningsregistrering läser metadata i en sammansättning och lägger till nödvändiga poster i registret, vilket gör att COM-klienter kan skapa .NET Framework-klasser transparent. När en klass har registrerats kan alla COM-klienter använda den som om klassen var en COM-klass. Klassen registreras bara en gång när sammansättningen är installerad. Instanser av klasser i sammansättningen kan inte skapas från COM förrän de faktiskt har registrerats.

Om du vill köra verktyget använder du Visual Studio Developer Command Prompt eller Visual Studio Developer PowerShell.

Syntax

regasm assemblyFile [options]

Parametrar

Parameter Description
assemblyFile Sammansättningen som ska registreras med COM.
Alternativ Description
/codebase Skapar en Codebase-post i registret. Codebase-posten anger filsökvägen för en sammansättning som inte är installerad i den globala sammansättningscacheminnet. Ange inte det här alternativet om du senare ska installera sammansättningen som du registrerar i den globala sammansättningscacheminnet. Vi rekommenderar starkt argumentet assemblyFile som du anger med alternativet vara en stark namngiven /codebase sammansättning.
/registered Anger att det här verktyget endast refererar till typbibliotek som redan har registrerats.
/asmpath:directory Anger en katalog som innehåller sammansättningsreferenser. Måste användas med alternativet /regfile .
/nologo Undertrycker microsofts startbanderoll.
/regfile [: regFile] Genererar den angivna .reg filen för sammansättningen, som innehåller de registerposter som behövs. Om du anger det här alternativet ändras inte registret. Du kan inte använda det här alternativet med /u alternativen eller /tlb .
/silent eller /s Undertrycker visning av lyckade meddelanden.
/tlb [: typeLibFile] Genererar ett typbibliotek från den angivna sammansättningen som innehåller definitioner av de tillgängliga typer som definierats i sammansättningen.
/unregister eller /u Avregistrerar de krea tabellklasser som finns i assemblyFile. Om du utelämnar det här alternativet kan Regasm.exe registrera de krea tabellklasser som finns i sammansättningen.
/verbose Anger utförligt läge. visar en lista över alla refererade sammansättningar som ett typbibliotek måste genereras för när det anges med alternativet /tlb .
/? eller /help Visar kommandosyntax och alternativ för verktyget.

Kommentar

De Regasm.exe kommandoradsalternativen är skiftlägesokänsliga. Du behöver bara ange tillräckligt med alternativ för att unikt identifiera det. Är till /nologo exempel /n likvärdigt med och /t: outfile.tlb motsvarar /tlb: outfile.tlb.

Kommentarer

Du kan använda /regfile alternativet för att generera en .reg fil som innehåller registerposterna i stället för att göra ändringarna direkt i registret. Du kan uppdatera registret på en dator genom att importera .reg-filen med verktyget Registereditorn (Regedit.exe). Den .reg filen innehåller inga registeruppdateringar som kan göras av användardefinierade registerfunktioner. Alternativet /regfile genererar endast registerposter för hanterade klasser. Det här alternativet genererar TypeLibID inte eller InterfaceID poster.

När du anger alternativet /tlb genererar och registrerar Regasm.exe ett typbibliotek som beskriver de typer som finns i sammansättningen. Regasm.exe placerar de genererade typbiblioteken i den aktuella arbetskatalogen eller katalogen som angetts för utdatafilen. Om du genererar ett typbibliotek för en sammansättning som refererar till andra sammansättningar kan flera typbibliotek genereras samtidigt. Du kan använda typbiblioteket för att ange typinformation till utvecklingsverktyg som Visual Studio. Använd inte alternativet /tlb om sammansättningen som du registrerar producerades av typbiblioteksimportören (Tlbimp.exe). Du kan inte exportera ett typbibliotek från en sammansättning som har importerats från ett typbibliotek. /tlb Att använda alternativet har samma effekt som att använda typbiblioteksexportören (Tlbexp.exe) och Regasm.exe, med undantag för att Tlbexp.exe inte registrerar det typbibliotek som skapas. Om du använder /tlb alternativet för att registrera ett typbibliotek kan du använda /tlb alternativet med /unregister alternativet för att avregistrera typbiblioteket. Om du använder de två alternativen tillsammans avregistreras typbiblioteket och gränssnittsposterna, vilket kan rensa registret avsevärt.

När du registrerar en sammansättning för användning av COM lägger Regasm.exe till poster i registret på den lokala datorn. Mer specifikt skapar den versionsberoende registernycklar som gör att flera versioner av samma sammansättning kan köras sida vid sida på en dator. Första gången en sammansättning registreras skapas en nyckel på den översta nivån för sammansättningen och en unik undernyckel skapas för den specifika versionen. Varje gång du registrerar en ny version av sammansättningen skapar Regasm.exe en undernyckel för den nya versionen.

Tänk dig till exempel ett scenario där du registrerar den hanterade komponenten, myComp.dll version 1.0.0.0 för användning av COM. Senare registrerar du myComp.dll version 2.0.0.0. Du avgör att alla COM-klientprogram på datorn använder myComp.dll version 2.0.0.0 och du bestämmer dig för att avregistrera myComponent.dll version 1.0.0.0. Med det här registerschemat kan du avregistrera myComp.dll version 1.0.0.0 eftersom endast undernyckeln version 1.0.0.0 tas bort.

När du har registrerat en sammansättning med hjälp av Regasm.exe kan du installera den i den globala sammansättningscacheminnet så att den kan aktiveras från alla COM-klienter. Om sammansättningen bara ska aktiveras av ett enda program kan du placera den i programmets katalog. /codebase Alternativet är ett alternativ till att använda det globala sammansättningscacheminnet. Platsen för sammansättningen under registreringen registreras dock globalt och aktiveringen misslyckas om sammansättningen flyttas. Om sammansättningen inte hittas genom avsökning/codebase läser alternativet in sammansättningen i en inläsningskontext som har ytterligare överväganden dokumenterade i Assembly.LoadFrom.

Exempel

Följande kommando registrerar alla offentliga klasser som finns i myTest.dll.

regasm myTest.dll

Följande kommando genererar filen myTest.reg, som innehåller alla nödvändiga registerposter. Det här kommandot uppdaterar inte registret.

regasm myTest.dll /regfile:myTest.reg

Följande kommando registrerar alla offentliga klasser i myTest.dlloch genererar och registrerar typbiblioteket myTest.tlb, som innehåller definitioner av alla offentliga typer som definierats i myTest.dll.

regasm myTest.dll /tlb:myTest.tlb

Se även