CorBindToRuntimeEx İşlevi

Yönetilmeyen konakların ortak dil çalışma zamanını (CLR) bir işleme yüklemesini sağlar. CorBindToRuntime ve CorBindToRuntimeEx işlevleri aynı işlemi gerçekleştirir, ancak CorBindToRuntimeEx işlevi CLR'nin davranışını belirtmek için bayraklar ayarlamanıza olanak tanır.

Bu işlev .NET Framework 4'te kullanım dışı bırakılmıştır.

Bu işlev, bir konağın aşağıdakileri gerçekleştirmesine izin veren bir dizi parametre alır:

  • Yüklenecek çalışma zamanının sürümünü belirtin.

  • Sunucu veya iş istasyonu derlemesinin yüklenip yüklenmeyeceğini belirtin.

  • Eşzamanlı çöp toplama veya eşzamanlı olmayan çöp toplama işleminin yapılıp yapılmadığını denetleme.

Uyarı

Eşzamanlı çöp toplama, Intel Itanium mimarisini (eski adıyla IA-64) uygulayan 64 bit sistemlerde WOW64 x86 öykünücüsü çalıştıran uygulamalarda desteklenmez. 64 bit Windows sistemlerinde WOW64 kullanma hakkında daha fazla bilgi için bkz. 32 bit Uygulamaları Çalıştırma.

  • Derlemelerin etki alanı nötr olarak yüklenip yüklenmediğini denetleme.

  • Başlatılmadan önce CLR örneğini yapılandırmak için ek seçenekler ayarlamak için kullanılabilecek bir ICorRuntimeHost arabirim işaretçisi alın.

Sözdizimi

HRESULT CorBindToRuntimeEx (
    [in]  LPCWSTR      pwszVersion,
    [in]  LPCWSTR      pwszBuildFlavor,
    [in]  DWORD        startupFlags,
    [in]  REFCLSID     rclsid,
    [in]  REFIID       riid,
    [out] LPVOID FAR  *ppv
);

Parametreler

pwszVersion [in] Yüklemek istediğiniz CLR sürümünü açıklayan bir dize.

.NET Framework'teki sürüm numarası noktalarla ayrılmış dört bölümden oluşur: major.minor.build.revision. Olarak pwszVersion geçirilen dizenin "v" karakteriyle başlaması ve ardından sürüm numarasının ilk üç bölümüyle (örneğin, "v1.0.1529") başlaması gerekir.

CLR'nin bazı sürümleri, CLR'nin önceki sürümleriyle uyumluluğu belirten bir ilke deyimiyle yüklenir. Varsayılan olarak, başlangıç dolgusu ilke deyimlerine pwszVersion göre değerlendirilir ve istenen sürümle uyumlu çalışma zamanının en son sürümünü yükler. Bir konak, aşağıda açıklandığı gibi parametresi için startupFlags değerini STARTUP_LOADER_SAFEMODE geçirerek dolguyu ilke değerlendirmesini atlayıp belirtilen pwszVersion tam sürümü yüklemeye zorlayabilir.

Çağıran için pwszVersionCorBindToRuntimeEx null değerini belirtirse, sürüm numaraları .NET Framework 4 çalışma zamanından daha düşük olan yüklü çalışma zamanları kümesini tanımlar ve bu kümeden çalışma zamanının en son sürümünü yükler. .NET Framework 4 veya üzerini yüklemez ve önceki bir sürüm yüklü değilse başarısız olur. Null değerinin geçirilmesinin konağa çalışma zamanının hangi sürümünün yüklendiği üzerinde denetim sağlamadığını unutmayın. Bu yaklaşım bazı senaryolarda uygun olsa da, konağın yüklenecek belirli bir sürüm sağlaması kesinlikle önerilir.

pwszBuildFlavor [in] Sunucunun mu yoksa CLR'nin iş istasyonu derlemesinin mi yüklendiğini belirten bir dize. Geçerli değerler: svr ve wks. Sunucu derlemesi, atık toplama için birden çok işlemciden yararlanmak üzere iyileştirilmiştir ve iş istasyonu derlemesi tek işlemcili bir makinede çalışan istemci uygulamaları için en iyi duruma getirilmiştir.

null olarak ayarlanırsa pwszBuildFlavor iş istasyonu derlemesi yüklenir. Tek işlemcili bir makinede çalışırken, iş istasyonu derlemesi olarak ayarlanmış svrolsa pwszBuildFlavor bile her zaman yüklenir. Ancak, olarak ayarlanırsa svr ve eşzamanlı çöp toplama belirtilirse pwszBuildFlavor (parametrenin açıklamasına startupFlags bakın), sunucu derlemesi yüklenir.

startupFlags [in] STARTUP_FLAGS sabit listesi değerlerinin birleşimi. Bu bayraklar eşzamanlı çöp toplamayı, etki alanı nötr kodunu ve parametresinin pwszVersion davranışını denetler. Bayrak ayarlı değilse varsayılan değer tek etki alanıdır. Aşağıdaki değerler geçerlidir:

  • STARTUP_CONCURRENT_GC

  • STARTUP_LOADER_OPTIMIZATION_SINGLE_DOMAIN

  • STARTUP_LOADER_OPTIMIZATION_MULTI_DOMAIN

  • STARTUP_LOADER_OPTIMIZATION_MULTI_DOMAIN_HOST

  • STARTUP_LOADER_SAFEMODE

  • STARTUP_LOADER_SETPREFERENCE

  • STARTUP_SERVER_GC

  • STARTUP_HOARD_GC_VM

  • STARTUP_SINGLE_VERSION_HOSTING_INTERFACE

  • STARTUP_LEGACY_IMPERSONATION

  • STARTUP_DISABLE_COMMITTHREADSTACK

  • STARTUP_ALWAYSFLOW_IMPERSONATION

Bu bayrakların açıklamaları için bkz. STARTUP_FLAGS numaralandırması.

rclsid [in] CLSIDICorRuntimeHost veya ICLRRuntimeHost arabirimini uygulayan ortak sınıfın değeri. Desteklenen değerler CLSID_CorRuntimeHost veya CLSID_CLRRuntimeHost.

riid [in] IID 'den istenen arabirimin rclsid. Desteklenen değerler IID_ICorRuntimeHost veya IID_ICLRRuntimeHost.

ppv [out] için döndürülen arabirim işaretçisi riid.

Açıklamalar

Var olmayan bir çalışma zamanı sürümü belirtirse pwszVersion , CorBindToRuntimeEx CLR_E_SHIM_RUNTIMELOAD HRESULT değerini döndürür.

Windows Kimliği Yürütme Bağlamı ve Akışı

CLR'nin WindowsIdentity 1. sürümünde, nesne yeni iş parçacıkları, iş parçacığı havuzları veya zamanlayıcı geri çağırmaları gibi zaman uyumsuz noktalar arasında akış yapmaz. CLR'nin 2.0 sürümünde bir ExecutionContext nesne, şu anda yürütülen iş parçacığı hakkında bazı bilgileri sarmalar ve bunu uygulama etki alanı sınırları arasında değil, zaman uyumsuz herhangi bir noktaya akıtılır. Benzer şekilde, WindowsIdentity nesne herhangi bir zaman uyumsuz nokta boyunca da akar. Bu nedenle, iş parçacığındaki geçerli kimliğe bürünme (varsa) de akar.

Akışı iki şekilde değiştirebilirsiniz:

  1. İş parçacığı başına akışı engellemek için ayarları değiştirerek ExecutionContext (bkz SuppressFlow. , SuppressFlowve SuppressFlowWindowsIdentity yöntemleri).

  2. İşlem varsayılan modunu sürüm 1 uyumluluk moduna değiştirerek, WindowsIdentity geçerli iş parçacığındaki ayarlardan bağımsız olarak ExecutionContext nesnenin herhangi bir zaman uyumsuz nokta boyunca akmaması. Varsayılan modu nasıl değiştirdiğiniz, CLR'yi yüklemek için yönetilen yürütülebilir dosya mı yoksa yönetilmeyen bir barındırma arabirimi mi kullandığınıza bağlıdır:

    1. Yönetilen yürütülebilir dosyalar için legacyImpersonationPolicy> öğesinin< özniteliğini olarak trueayarlamanız enabled gerekir.

    2. Yönetilmeyen barındırma arabirimleri için işlevi çağırırken parametresinde startupFlags bayrağını CorBindToRuntimeEx ayarlayınSTARTUP_LEGACY_IMPERSONATION.

    Sürüm 1 uyumluluk modu tüm işlem ve işlemdeki tüm uygulama etki alanları için geçerlidir.

Gereksinimler

Platform: Bkz. Sistem Gereksinimleri.

Üstbilgi: MSCorEE.h

Kitaplık: MSCorEE.dll

.NET Framework Sürümleri: 1.0 sürümünden itibaren kullanılabilir

Ayrıca bakınız