Вы можете P / Invoke ExitWindowsEx:
http://www.pinvoke.net/default.aspx/user32/ExitWindowsEx.html
Собираем все вместе:
using System.Runtime.InteropServices;
class Class1
{
[DllImport("user32.dll")]
static extern bool ExitWindowsEx(uint uFlags, uint dwReason);
[STAThread]
static void Main(string[] args)
{
ExitWindowsEx(ExitWindows.LogOff, ShutdownReason.MajorOther | ShutdownReason.MinorOther);
}
}
[Flags]
public enum ExitWindows : uint
{
// ONE of the following five:
LogOff = 0x00,
ShutDown = 0x01,
Reboot = 0x02,
PowerOff = 0x08,
RestartApps = 0x40,
// plus AT MOST ONE of the following two:
Force = 0x04,
ForceIfHung = 0x10,
}
[Flags]
enum ShutdownReason : uint
{
MajorApplication = 0x00040000,
MajorHardware = 0x00010000,
MajorLegacyApi = 0x00070000,
MajorOperatingSystem = 0x00020000,
MajorOther = 0x00000000,
MajorPower = 0x00060000,
MajorSoftware = 0x00030000,
MajorSystem = 0x00050000,
MinorBlueScreen = 0x0000000F,
MinorCordUnplugged = 0x0000000b,
MinorDisk = 0x00000007,
MinorEnvironment = 0x0000000c,
MinorHardwareDriver = 0x0000000d,
MinorHotfix = 0x00000011,
MinorHung = 0x00000005,
MinorInstallation = 0x00000002,
MinorMaintenance = 0x00000001,
MinorMMC = 0x00000019,
MinorNetworkConnectivity = 0x00000014,
MinorNetworkCard = 0x00000009,
MinorOther = 0x00000000,
MinorOtherDriver = 0x0000000e,
MinorPowerSupply = 0x0000000a,
MinorProcessor = 0x00000008,
MinorReconfig = 0x00000004,
MinorSecurity = 0x00000013,
MinorSecurityFix = 0x00000012,
MinorSecurityFixUninstall = 0x00000018,
MinorServicePack = 0x00000010,
MinorServicePackUninstall = 0x00000016,
MinorTermSrv = 0x00000020,
MinorUnstable = 0x00000006,
MinorUpgrade = 0x00000003,
MinorWMI = 0x00000015,
FlagUserDefined = 0x40000000,
FlagPlanned = 0x80000000
}
malloc
сам по себе не обнуляет память, но многие операционные системы обнуляют память, которую ваша программа запрашивает по соображениям безопасности (чтобы один процесс не мог получить доступ к потенциально конфиденциальной информации, которая использовалась другим процессом).
Функция malloc ()
не устанавливает для выделенной памяти какое-либо конкретное значение. Если вы хотите убедиться, что объем памяти равен нулю, используйте calloc ()
или эквивалент. В противном случае вы получите то, что было раньше (в вашем случае это может быть ноль).
Значение в выделенной памяти официально не определено. В C99 указано: Функция malloc выделяет пространство для объекта, размер которого определяется размером и значение которого не определено.
malloc () может делать все, что хочет, включая обнуление. Это может быть намеренно, побочным эффектом реализации, или у вас может быть просто много памяти, которая оказывается равной 0.
FWIW на OS X с Apple gcc 4.0.1 Я не могу заставить его выйти, не так ли? 0 даже делаю много распределения:
for( idx = 0; idx < 100000; idx++ ) {
i = (int *) malloc(sizeof(int));
printf("%d\n", *i);
}
Вы определенно не можете полагаться на то, что он равен 0. malloc большой кусок и сбросьте его, чтобы увидеть.
Malloc не должен заполнять память. По соображениям производительности релизные версии часто ничего не делают с памятью. «Безопасная» библиотека может иметь реализацию malloc, очищающую память. Это зависит от разработчика библиотеки. Есть несколько общих шаблонов, которые заполняются в памяти различными библиотеками отладки компилятора, которые объясняются в этой теме о переполнении стека .