當前位置: 首頁>>代碼示例>>C#>>正文


C# SafeHandles.SafeProcessHandle類代碼示例

本文整理匯總了C#中Microsoft.Win32.SafeHandles.SafeProcessHandle的典型用法代碼示例。如果您正苦於以下問題:C# SafeProcessHandle類的具體用法?C# SafeProcessHandle怎麽用?C# SafeProcessHandle使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


SafeProcessHandle類屬於Microsoft.Win32.SafeHandles命名空間,在下文中一共展示了SafeProcessHandle類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: AddProcess

 public void AddProcess(SafeProcessHandle processHandle)
 {
     ValidateDisposed();
     if (!AssignProcessToJobObject(_handle, processHandle))
     {
         throw new InvalidOperationException("Unable to add the process");
     }
 }
開發者ID:mjheitland,項目名稱:TableTweaker,代碼行數:8,代碼來源:ChildProcessManager.cs

示例2: DuplicateHandle

 internal static extern bool DuplicateHandle(
     SafeProcessHandle hSourceProcessHandle,
     SafeHandle hSourceHandle,
     SafeProcessHandle hTargetProcess,
     out SafeWaitHandle targetHandle,
     int dwDesiredAccess,
     bool bInheritHandle,
     int dwOptions
 );
開發者ID:noahfalk,項目名稱:corefx,代碼行數:9,代碼來源:Interop.DuplicateHandle_SafeProcessHandle.cs

示例3: DuplicateHandle

		SafeProcessHandle DuplicateHandle(SafeProcessHandle process, IntPtr handle, bool throwOnFail = true)
		{
			SafeProcessHandle dupHandle;
			if (!Win32.DuplicateHandle(process, handle, Win32.GetCurrentProcess(), out dupHandle, 0, false, Win32.DUPLICATE_SAME_ACCESS))
				if (throwOnFail)
					throw new Win32Exception();
				else
					return null;
			return dupHandle;
		}
開發者ID:xyandro,項目名稱:NeoEdit,代碼行數:10,代碼來源:SharedMemoryBinaryData.cs

示例4: GetExitCodeProcess

		public static bool GetExitCodeProcess (SafeProcessHandle processHandle, out int exitCode)
		{
			bool release = false;
			try {
				processHandle.DangerousAddRef (ref release);
				return GetExitCodeProcess (processHandle.DangerousGetHandle (), out exitCode);
			} finally {
				if (release)
					processHandle.DangerousRelease ();
			}
		}
開發者ID:BogdanovKirill,項目名稱:mono,代碼行數:11,代碼來源:NativeMethods.cs

示例5: Protect

		public Protect(SafeProcessHandle handle, VirtualQueryInfo info, int protect)
		{
			this.handle = handle;
			this.info = info;
			this.protect = protect;

			if (protect == info.Protect)
				return;

			int oldProtect;
			if (!Win32.VirtualProtectEx(handle.DangerousGetHandle(), (IntPtr)info.StartAddress, (IntPtr)info.RegionSize, protect, out oldProtect))
				throw new Win32Exception();
		}
開發者ID:xyandro,項目名稱:NeoEdit,代碼行數:13,代碼來源:Protect.cs

示例6: DuplicateHandle

		public static bool DuplicateHandle(HandleRef hSourceProcessHandle, HandleRef hSourceHandle, HandleRef hTargetProcess,
			out SafeProcessHandle targetHandle, int dwDesiredAccess, bool bInheritHandle, int dwOptions)
		{
				MonoIOError error;
				IntPtr nakedTargetHandle;
				bool ret = MonoIO.DuplicateHandle (hSourceProcessHandle.Handle, hSourceHandle.Handle, hTargetProcess.Handle,
					out nakedTargetHandle, dwDesiredAccess, bInheritHandle ? 1 : 0, dwOptions, out error);

				if (error != MonoIOError.ERROR_SUCCESS)
					throw MonoIO.GetException (error);

				targetHandle = new SafeProcessHandle (nakedTargetHandle, true);
				return ret;
		}
開發者ID:BogdanovKirill,項目名稱:mono,代碼行數:14,代碼來源:NativeMethods.cs

示例7: ProcessWaitHandle

        internal ProcessWaitHandle( SafeProcessHandle processHandle): base() {
            SafeWaitHandle waitHandle = null;
            bool succeeded = NativeMethods.DuplicateHandle(
                new HandleRef(this, NativeMethods.GetCurrentProcess()),
                processHandle,
                new HandleRef(this, NativeMethods.GetCurrentProcess()),
                out waitHandle,
                0,
                false,
                NativeMethods.DUPLICATE_SAME_ACCESS);
                    
            if (!succeeded) {                    
                Marshal.ThrowExceptionForHR(Marshal.GetHRForLastWin32Error());
            }

            this.SafeWaitHandle = waitHandle;         
        }
開發者ID:gbarnett,項目名稱:shared-source-cli-2.0,代碼行數:17,代碼來源:processwaithandle.cs

示例8: ProcessWaitHandle

        internal ProcessWaitHandle(SafeProcessHandle processHandle)
        {
            // Get the process ID from the process handle.  The handle is just a facade that wraps
            // the process ID, and closing the handle won't affect the process or its ID at all.
            // So we can grab it, and it's not "dangerous".
            int processId = (int)processHandle.DangerousGetHandle();

            // Create a wait state holder for this process ID.  This gives us access to the shared
            // wait state associated with this process.
            _waitStateHolder = new ProcessWaitState.Holder(processId);

            // Get the wait state's event, and use that event's safe wait handle
            // in place of ours.  This will let code register for completion notifications
            // on this ProcessWaitHandle and be notified when the wait state's handle completes.
            ManualResetEvent mre = _waitStateHolder._state.EnsureExitedEvent();
            this.SetSafeWaitHandle(mre.GetSafeWaitHandle());
        }
開發者ID:noahfalk,項目名稱:corefx,代碼行數:17,代碼來源:ProcessWaitHandle.Unix.cs

示例9: ProcessWaitHandle

        internal ProcessWaitHandle(SafeProcessHandle processHandle)
        {
            SafeWaitHandle waitHandle = null;
            SafeProcessHandle currentProcHandle = Interop.mincore.GetCurrentProcess();
            bool succeeded = Interop.mincore.DuplicateHandle(
                currentProcHandle,
                processHandle,
                currentProcHandle,
                out waitHandle,
                0,
                false,
                Interop.DUPLICATE_SAME_ACCESS);

            if (!succeeded)
            {
                Marshal.ThrowExceptionForHR(Marshal.GetHRForLastWin32Error());
            }

            this.SetSafeWaitHandle(waitHandle);
        }
開發者ID:gitter-badger,項目名稱:corefx,代碼行數:20,代碼來源:ProcessWaitHandle.Windows.cs

示例10: ProcessWaitHandle

        internal ProcessWaitHandle( SafeProcessHandle processHandle): base() {
            SafeWaitHandle waitHandle = null;
            bool succeeded = NativeMethods.DuplicateHandle(
                new HandleRef(this, NativeMethods.GetCurrentProcess()),
                processHandle,
                new HandleRef(this, NativeMethods.GetCurrentProcess()),
                out waitHandle,
                0,
                false,
                NativeMethods.DUPLICATE_SAME_ACCESS);
                    
            if (!succeeded) {                    
#if MONO
                // In Mono, Marshal.GetHRForLastWin32Error is not implemented;
                // and also DuplicateHandle throws its own exception rather
                // than returning false on error, so this code is unreachable.
                throw new SystemException("Unknown error in DuplicateHandle");
#else
                Marshal.ThrowExceptionForHR(Marshal.GetHRForLastWin32Error());
#endif
            }

            this.SafeWaitHandle = waitHandle;         
        }
開發者ID:ItsVeryWindy,項目名稱:mono,代碼行數:24,代碼來源:processwaithandle.cs

示例11: GetProcessIdFromHandle

 public static int GetProcessIdFromHandle(SafeProcessHandle processHandle) {
     if (IsNt)
         return NtProcessManager.GetProcessIdFromHandle(processHandle);
     else
         throw new PlatformNotSupportedException(SR.GetString(SR.WinNTRequired));
 }
開發者ID:JBlacks,項目名稱:referencesource,代碼行數:6,代碼來源:ProcessManager.cs

示例12: GetProcessPriorityBoost

 internal static extern bool GetProcessPriorityBoost(SafeProcessHandle handle, out bool disabled);
開發者ID:noahfalk,項目名稱:corefx,代碼行數:1,代碼來源:Interop.GetProcessPriorityBoost.cs

示例13: SetPriorityClass

		public static bool SetPriorityClass(SafeProcessHandle handle, int priorityClass)
		{
			bool release = false;
			try {
				handle.DangerousAddRef (ref release);
				return SetPriorityClass (handle.DangerousGetHandle (), priorityClass);
			} finally {
				if (release)
					handle.DangerousRelease ();
			}
		}
開發者ID:BogdanovKirill,項目名稱:mono,代碼行數:11,代碼來源:NativeMethods.cs

示例14: GetProcessTimes

		public static bool GetProcessTimes (SafeProcessHandle handle, out long creation, out long exit, out long kernel, out long user)
		{
			bool release = false;
			try {
				handle.DangerousAddRef (ref release);
				return GetProcessTimes (handle.DangerousGetHandle (), out creation, out exit, out kernel, out user);
			} finally {
				if (release)
					handle.DangerousRelease ();
			}
		}
開發者ID:BogdanovKirill,項目名稱:mono,代碼行數:11,代碼來源:NativeMethods.cs

示例15: SetProcessWorkingSetSize

		public static bool SetProcessWorkingSetSize (SafeProcessHandle handle, IntPtr min, IntPtr max)
		{
			bool release = false;
			try {
				handle.DangerousAddRef (ref release);
				return SetProcessWorkingSetSize (handle.DangerousGetHandle (), min, max);
			} finally {
				if (release)
					handle.DangerousRelease ();
			}
		}
開發者ID:BogdanovKirill,項目名稱:mono,代碼行數:11,代碼來源:NativeMethods.cs


注:本文中的Microsoft.Win32.SafeHandles.SafeProcessHandle類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。