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