Peržiūrėkite kitus produktus, kuriems taikomas šis straipsnis.
Simptomai
Kai automatizuoti Microsoft Office "Microsoft Visual Basic.NET" arba "Microsoft Visual C# .NET", "Office" taikomoji programa neišeis, kai skambinate į metodą Baigti.
Priežastis
Kai Visual Studio .NET iš valdomo kodo skambina COM objektu, jis automatiškai sukuria "Runtime Callable Wrapper" (RCW). RCW maršalai skambina tarp .NET taikomosios programos ir COM objekto. RCW išlaiko COM objekto nuorodų skaičių. Todėl, jei visos nuorodos nebuvo išleistos RCW, COM objektas neišeis.
Sprendimas
Norėdami įsitikinti, kad Office programa išeina, nustatykite, ar jūsų automatizavimo kodas atitinka šiuos kriterijus:
-
Kiekvieną objektą paskelbti nauju kintamuoju. Pvz., pakeiskite šią kodo eilutę:
oBook = oExcel.Workbooks.Add()
Pakeiskite į šį:
dim oBooks as Excel.Workbooks oBooks = oExcel.Workbooks oBook = oBooks.Add()
-
Naudokite System.Runtime.InteropServices.Marshal.ReleaseComObject cikle, kol grąžins 0, kai baigsite naudoti objektą. System.Runtime.InteropServices.Marshal.ReleaseComObject išleidžia RCW nuorodų skaičių, o ciklas užtikrina, kad esantis COM komponentas bus išleistas neatsižvelgiant į tai, kiek kartų jis iš naujo įvedė CLR.
-
Norėdami paleisti nuorodą į kintamąjį, nustatykite kintamąjį, lygų Nieko arba Null.
-
Naudokite programos objekto Office metodą Baigti, kad nurodykite serveriui išjungti.
Būsena
Taip yra pagal dizainą.
Daugiau informacijos
Veiksmai, kaip atkurti veikimą
-
Paleiskite Visual Studio .NET.
-
Meniu Failas spustelėkite Naujas, tada spustelėkite Project. Dalyje Visual Basic Projektai pasirinkite Windows, tada spustelėkite Gerai.
Pastaba Forma1 sukuriama pagal numatytuosius nustatymus. -
Įtraukite nuorodą į Microsoft Excel biblioteką. Norėdami tai atlikti, vykdykite toliau nurodytus veiksmus.
-
Meniu Project spustelėkite Įtraukti nuorodą.
-
Skirtuke COM raskite objekto biblioteką, Excel pasirinkite.
"Microsoft Excel 2002": "Microsoft Excel 10.0 Object LibraryNote " Jei to dar nepadarėte, rekomenduojame atsisiųsti ir įdiegti "Microsoft Office XP" pirminius tarpinių mazgų rinkinius (PIAS). Daugiau informacijos apie Office XP PIAs" rasite šiame "Microsoft" žinių bazės straipsnyje:328912 Microsoft Office XP" pirminius tarpinių mazgų rinkinius (PIAs) galima atsisiųsti Jei Microsoft Office Excel 2003": Microsoft Excel 11.0 objektų biblioteka
-
Spustelėkite Gerai dialogo lange Įtraukti nuorodas, kad sutikite su savo pasirinkimais.
-
-
Meniu Rodymas spustelėkite Įrankių komplektas, tada vilkite mygtuko valdiklį į Form1.
-
Dukart spustelėkite Button1.
Pastaba Rodomas formos kodo langas. -
Formos1.vb viršuje įtraukite šį kodą:
Imports Microsoft.Office.Interop
-
Kodo lange pakeiskite šį kodą:
Private Sub Button1_Click(ByVal sender As System.Object, _ ByVal e As System.EventArgs) Handles Button1.Click End Sub
Pakeiskite šį kodą:
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim oApp As New Excel.Application() Dim oBook As Excel.Workbook = oApp.Workbooks.Add Dim oSheet As Excel.Worksheet = oApp.ActiveSheet oSheet = Nothing oBook.Close(False) oBook = Nothing oApp.Quit() oApp = Nothing Debug.WriteLine("Sleeping...") System.Threading.Thread.Sleep(5000) Debug.WriteLine("End Excel") End Sub
-
Paspauskite F5, kad paleisite taikomąją programą.
-
Atidarykite Windows užduočių tvarkytuvą. Lange Visual Studio langą Išvestis, kad pamatytumėte derinimo pranešimus. Spustelėkite komandos mygtuką. Atkreipkite dėmesį, kad Excel.exe rodomas sąraše Procesai.
-
Užduočių Excel vis dar veikia užduočių sąraše net tada, kai taikomoji programa baigia miegoti. Uždarykite dialogo langą ir atkreipkite dėmesį Excel neberodoma sąraše Procesai.
-
Kai atlikite veiksmus, nurodytus skyriuje "Sprendimas", Office programa išeis, kai ji išleis paskutinį kintamąjį. Pakeiskite funkciją atlikdami 5 veiksmą naudodami šį kodą:
Private Sub NAR(ByVal o As Object) Try While (System.Runtime.InteropServices.Marshal.ReleaseComObject(o) > 0) End While Catch Finally o = Nothing End Try End Sub Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim oApp As New Excel.Application() Dim oBooks As Excel.Workbooks = oApp.Workbooks Dim oBook As Excel.Workbook = oBooks.Add Dim oSheet As Excel.Worksheet = oApp.ActiveSheet NAR(oSheet) oBook.Close(False) NAR(oBook) NAR(oBooks) oApp.Quit() NAR(oApp) Debug.WriteLine("Sleeping...") System.Threading.Thread.Sleep(5000) Debug.WriteLine("End Excel") End Sub
Jei naudojate "Visual C# .NET", nurodyti FUNKCIJOS NAR() kodą:
private void NAR(object o)
{
try
{
while (System.Runtime.InteropServices.Marshal.ReleaseComObject(o) > 0) ;
}
catch {}
finally
{
o = null;
}
}
Pastaba Pradedant nuo .NET Framework 2.0, galite naudoti System.Runtime.InteropServices.Marshal.FinalReleaseComObject, o ne ciklą skambinti System.Runtime.InteropServices.Marshal.ReleaseComObject, kad pasiektume tą patį rezultatą.
Trikčių šalinimas
Pastaba Jei atlikite veiksmus, aprašytus skyriuje "Veikimo atkūrimo veiksmai", o serveris vis tiek neišsijungia, galite naudoti GC. Collect() metodas ir GC. WaitForPendingFinalizers() metodas, kai atleisite paskutinį objektą. Kadangi vykdyklė atlieka šiukšlių rinkinį RCW, GC. Collect() metodas verčia šiukšlių rinktuvą veikti ir gali išleisti visas nuorodas, kurias vis dar turi RCW. The GC. Collect() metodas bando susigrąžinti maksimalią prieinamą atmintį. Atkreipkite dėmesį, kad tai negarantuoja, kad visa atmintis bus atlaisvinta.
Taikoma
Šis straipsnis taip pat taikomas:
-
"Microsoft Visual Basic.NET" (visi leidimai)
-
Microsoft Visual C# .NET (visi leidimai)
-
Microsoft Office 2016 (visi leidimai)
-
Microsoft Office 2013 m. (visi leidimai)