Fungsi Eksternal
Artikel ini menjelaskan dukungan bahasa F# untuk memanggil fungsi dalam kode asli.
Sintaks
[<DllImport( arguments )>]
extern declaration
Keterangan
Dalam sintaks sebelumnya, arguments
mewakili argumen yang disediakan ke System.Runtime.InteropServices.DllImportAttribute
atribut . Argumen pertama adalah string{i> System.Runtime.InteropServices.DllImportAttribute, seperti konvensi panggilan.
Asumsikan Anda memiliki C++ DLL asli yang berisi fungsi yang diekspor berikut.
#include <stdio.h>
extern "C" void __declspec(dllexport) HelloWorld()
{
printf("Hello world, invoked by F#!\n");
}
Anda dapat memanggil fungsi ini dari F# dengan menggunakan kode berikut.
open System.Runtime.InteropServices
module InteropWithNative =
[<DllImport(@"C:\bin\nativedll", CallingConvention = CallingConvention.Cdecl)>]
extern void HelloWorld()
InteropWithNative.HelloWorld()
Interoperabilitas dengan kode asli disebut sebagai pemanggilan platform dan merupakan fitur dari CLR. Untuk informasi selengkapnya, lihat Mengoperasikan dengan Kode Tidak Terkelola. Informasi di bagian tersebut berlaku untuk F#.
Menentukan Parameter dalam Fungsi Eksternal
Saat Anda mendeklarasikan fungsi eksternal dengan nilai atau parameter yang dikembalikan, Anda menggunakan sintaks yang mirip dengan C. Anda memiliki opsi untuk menggunakan deklarasi terkelola (di mana CLR akan melakukan beberapa konversi otomatis antara jenis asli dan .NET) dan deklarasi yang tidak dikelola, yang mungkin menawarkan performa yang lebih baik dalam beberapa keadaan. Misalnya, fungsi Windows GetBinaryTypeW dapat dideklarasikan dengan dua cara berbeda:
// Using automatic marshaling of managed types
[<DllImport("kernel32.dll",
CallingConvention = CallingConvention.StdCall,
CharSet = CharSet.Unicode,
ExactSpelling = true)>]
extern bool GetBinaryTypeW([<MarshalAs(UnmanagedType.LPWStr)>] string lpApplicationName, uint& lpBinaryType);
MarshalAs(UnmanagedType.LPWStr)
menginstruksikan CLR untuk melakukan konversi otomatis antara representasi string asli .NET string
dan Windows saat fungsi dipanggil. uint&
menyatakan uint
bahwa akan diteruskan byref
, yaitu, sebagai penunjuk terkelola. Untuk mendapatkan pointer terkelola, Anda menggunakan alamat &
operator.
Secara bergantian, Anda mungkin ingin mengelola marsekal jenis data secara manual dan mendeklarasikan fungsi eksternal hanya menggunakan jenis yang tidak dikelola.
// Using unmanaged types
[<DllImport("kernel32.dll", CallingConvention = CallingConvention.StdCall, ExactSpelling = true)>]
extern int GetBinaryTypeW(nativeint lpApplicationName, uint* lpBinaryType);
Anda dapat menggunakanMarshal.StringToHGlobalUni untuk mengonversi string .NET ke format asli dan menerima pointer (nativeint
) ke dalamnya yang dapat disediakan ke lpApplicationName
.
Untuk mendapatkan pointer ke bilangan &&
bulat, gunakan penunjuk operator atau fixed
kata kunci.
Lihat juga
Saran dan Komentar
https://aka.ms/ContentUserFeedback.
Segera hadir: Sepanjang tahun 2024 kami akan menghentikan penggunaan GitHub Issues sebagai mekanisme umpan balik untuk konten dan menggantinya dengan sistem umpan balik baru. Untuk mengetahui informasi selengkapnya, lihat:Kirim dan lihat umpan balik untuk