다음을 통해 공유


Marshal.StringToHGlobalAuto(String) 메서드

정의

필요할 때 ANSI 형식으로 변환하여 관리되는 String의 내용을 관리되지 않는 메모리로 복사합니다.

public:
 static IntPtr StringToHGlobalAuto(System::String ^ s);
public static IntPtr StringToHGlobalAuto (string? s);
public static IntPtr StringToHGlobalAuto (string s);
[System.Security.SecurityCritical]
public static IntPtr StringToHGlobalAuto (string s);
static member StringToHGlobalAuto : string -> nativeint
[<System.Security.SecurityCritical>]
static member StringToHGlobalAuto : string -> nativeint
Public Shared Function StringToHGlobalAuto (s As String) As IntPtr

매개 변수

s
String

복사할 관리되는 문자열입니다.

반환

IntPtr

nativeint

관리되지 않는 메모리에서 문자열이 복사된 주소이거나 snull인 경우 0입니다.

특성

예외

사용 가능한 메모리가 부족한 경우

예제

다음 예제에서는 관리 String 되는 클래스의 내용을 관리되지 않는 메모리로 변환한 다음, 완료되면 관리되지 않는 메모리를 삭제하는 방법을 보여 줍니다.

using namespace System;
using namespace System::Runtime::InteropServices;

int main()
{
    // Create a managed string.
    String^ managedString = "Hello unmanaged world (from the managed world).";

    // Marshal the managed string to unmanaged memory.
    char*  stringPointer = (char*) Marshal::StringToHGlobalAuto(managedString).ToPointer();

    // Pass the string to an unmanaged API.

    // Always free the unmanaged string.
    Marshal::FreeHGlobal(IntPtr(stringPointer));

    return 0;
}

설명

StringToHGlobalAuto 는 사용자 지정 마샬링에 유용하거나 관리 코드와 관리되지 않는 코드를 혼합할 때 유용합니다. 이 메서드는 문자열에 필요한 관리되지 않는 메모리를 할당하므로 항상 를 호출 FreeHGlobal하여 메모리를 해제합니다. 이 메서드는 의 Marshal.PtrToStringAuto반대 기능을 제공합니다.

이 메서드는 포함된 null 문자를 복사하고 종료 null 문자를 포함합니다.

적용 대상

추가 정보