Marshal.StringToHGlobalUni(String) Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Копирует содержимое управляемого объекта String в неуправляемую память.
public:
static IntPtr StringToHGlobalUni(System::String ^ s);
[System.Security.SecurityCritical]
public static IntPtr StringToHGlobalUni (string s);
public static IntPtr StringToHGlobalUni (string? s);
public static IntPtr StringToHGlobalUni (string s);
[<System.Security.SecurityCritical>]
static member StringToHGlobalUni : string -> nativeint
static member StringToHGlobalUni : string -> nativeint
Public Shared Function StringToHGlobalUni (s As String) As IntPtr
Параметры
- s
- String
Копируемая управляемая строка.
Возвращаемое значение
nativeint
Адрес в неуправляемой памяти, куда скопирована строка s
, или значение 0, если строка s
имеет значение null
.
- Атрибуты
Исключения
Метод не может выделить в куче достаточное количество динамической памяти, присущей данному объекту.
Параметр s
превышает максимальную длину, разрешенную операционной системой.
Комментарии
StringToHGlobalUni полезно для пользовательского маршалинга или для использования при смешивании управляемого и неуправляемого кода. Так как этот метод выделяет неуправляемую память, необходимую для строки, всегда освобождайте память, вызывая .FreeHGlobal Этот метод предоставляет функциональность, противоположную Marshal.PtrToStringUni.
Этот метод копирует внедренные символы NULL и включает завершающий символ NULL.
Этот API отражает определение Юникода в Windows, которое представляет собой двухбайтовую кодировку UTF-16. На многих платформах, отличных от Windows, wchar_t
тип данных равен 4 байтам, а не 2 байтам. Обратитесь к компилятору, чтобы проверить, можно ли wchar_t
использовать или char16_t
следует использовать вместо него.