Go WASM 내보내기에서 함수 이름 노출
Go 코드를 WASM으로 컴파일할 때 함수 이름을 보존하려는 상황이 발생할 수 있습니다. 결과 .wasm 파일에. 기본적으로 표준 Go 컴파일러는 컴파일 프로세스 중에 함수 이름을 내보내지 않습니다.
함수 이름을 내보내려면 다음 두 가지 옵션이 있습니다.
1. 내장형 WASM 지향 Go 컴파일러인 TinyGo
TinyGo를 사용하면 //export 또는 //go:export 주석 지시문을 통해 함수 내보내기를 지원합니다. 예는 다음과 같습니다.
<code class="Go">//export multiply func multiply(x, y int) int { return x * y; }</code>
TinyGo로 컴파일할 때(예:tinygo build -o wasm.wasm -target wasm ./main.go) 곱셈 기능은 결과 WASM 파일에 노출됩니다.
2. 표준 Go 컴파일러 사용(실험)
표준 Go 컴파일러는 현재 TinyGo의 //export 지시문과 유사한 기능을 도입하기 위해 노력하고 있습니다. 하지만 이 기능은 아직 개발 중입니다. 대안으로, js.Global().Set(...) 함수를 사용하여 Go 함수를 JS 전역 네임스페이스의 속성으로 설정할 수 있습니다.
예:
<code class="Go">import ( "github.com/gopherjs/gopherjs/js" ) func main() { js.Global().Set("multiply", multiply) } func multiply(x, y int) int { return x * y; }</code>
이 접근 방식을 사용하면 전역 JavaScript 네임스페이스에 곱셈 함수를 노출하여 WASM 코드에서 액세스할 수 있습니다.
위 내용은 Go WASM에서 함수 이름을 내보내는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!