runtime.Pinner を使用して Go から C に 2D 配列を渡します
質問内容
GoからC関数に2D配列を渡そうとしていますvoid foo(in **float, out *double)
。この C 関数のラッパーが必要なので、Go 関数に func FooWrapper([][]float32) []float64
のような定義を持たせます。最も単純ですが、あまり効率的ではない実装は、以下に示す C 経由ですべてのメモリを割り当てることです。
リーリー
result データへのポインタを渡すことはできますか?私の知る限り、このポインターは C 関数に渡されるため固定されます。
runtime.Pinner.Unpin() が呼び出されるまでポインタを固定し続ける
runtime.Pinner について学びました。 。 pinnerを使用して別の実装を書いてみました:
リーリー
リーリー
runtime.Pinner を使用するのは間違っていますか (私の知る限り、スライス データを固定できる)。または、このコードに別のバグがあります。すべてのデータをCメモリに割り当ててコピーする以外に、3D(4Dなど)配列をC関数に渡す実装はありますか? 解決策私の問題に対する答えを見つけました。 malloc を使用するのは危険です。Go ポインタを C メモリに書き込もうとすると、GC が初期化されていないメモリを「不良」メモリとして識別する可能性があるため、malloc を calloc に変更すれば問題はありません。もちろん、これは最善の解決策ではありません。Go でメモリを割り当てるほうが高速かつ安全です。すべてのディスカッション
こちら.一个>
以上がruntime.Pinner を使用して Go から C に 2D 配列を渡しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

この記事では、go.modを介してGOモジュールの依存関係の管理、仕様、更新、競合解決をカバーすることについて説明します。セマンティックバージョンや定期的な更新などのベストプラクティスを強調しています。

この記事では、Debianシステムの下でPostgreSQLデータベースを監視するためのさまざまな方法とツールを紹介し、データベースのパフォーマンス監視を完全に把握するのに役立ちます。 1. PostgreSQLを使用して監視を監視するビューPostgreSQL自体は、データベースアクティビティを監視するための複数のビューを提供します。 PG_STAT_REPLICATION:特にストリームレプリケーションクラスターに適した複製ステータスを監視します。 PG_STAT_DATABASE:データベースサイズ、トランザクションコミット/ロールバック時間、その他のキーインジケーターなどのデータベース統計を提供します。 2。ログ分析ツールPGBADGを使用します
