Go でのポインタ演算
C とは異なり、Go ではポインタ演算はできません。 Go の FAQ に記載されているように、ポインター演算がないため、不正なアドレスが導出される可能性が排除され、安全性が向上します。さらに、最新のコンパイラとハードウェアでは、配列インデックス ループがポインタ算術ループの効率と一致するようにしています。
この制限にもかかわらず、安全でないパッケージを使用してポインタ算術を実行することは技術的には可能です。ただし、潜在的なリスクがあるため、これは強くお勧めしません。次の例を考えてみましょう。
package main import ( "fmt" "unsafe" ) func main() { vals := []int{10, 20, 30, 40} start := unsafe.Pointer(&vals[0]) // Pointer to the first element size := unsafe.Sizeof(int(0)) // Size of an int in bytes for i := 0; i < len(vals); i++ { item := *(*int)(unsafe.Pointer(uintptr(start) + size*uintptr(i))) // Dereference the pointer at the correct offset fmt.Println(item) } }
このコードはポインター演算を実行しているように見えますが、安全でないパッケージを使用すると未定義の動作が発生する可能性があり、例外的な場合にのみ考慮する必要があることを強調する必要があります。潜在的なリスクを回避するには、Go の組み込み配列インデックス付けまたは他の安全な代替手段を利用することをお勧めします。
以上がGo ではポインター演算は可能ですか? なぜ推奨されないのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。