ホームページ バックエンド開発 Golang golangの並列記述方法とは何ですか?

golangの並列記述方法とは何ですか?

Apr 11, 2023 am 09:14 AM

現代のソフトウェア開発では、コンピューターのハードウェア リソースを効率的に使用することが重要です。並列プログラミングは、マルチコア CPU を最大限に活用できるプログラミング方法です。他のプログラミング言語と比較して、Go 言語 (Golang とも呼ばれる) には同時プログラミングをサポートするツールとメカニズムが組み込まれているため、並列プログラミングの分野で広く使用され、認識されています。

この記事では、Golang で並列プログラミングを実装するためのいくつかの方法と技術、および適用可能なシナリオと注意事項を紹介します。

1. Goroutine とチャネル

Goroutine は、Golang が他のプログラミング言語から借用した並列プログラミング モデルです。これは軽量スレッドと呼ばれ、コンピューターのマルチコア処理能力をより効率的に利用します。各 Goroutine は Golang のランタイム システムによって自動的に管理され、開発者は go キーワードを実行して Goroutine を作成するだけで済みます。

例:

func main() {
    go func() {
        fmt.Println("Hello, Goroutine!")
    }()
    fmt.Println("Hello, World!")
}
ログイン後にコピー

このコードでは、匿名関数を作成し、go キーワードを使用してそれを Goroutine に変換します。プログラムは「Hello, World!」と「Hello, Goroutine!」を同時に出力します。

チャネルは、Golang のゴルーチン間の通信に使用されるメカニズムです。チャネルはあらゆる種類のデータの送信に使用できるため、異なるゴルーチン間でデータと制御情報を渡すことができます。

例:

func worker(id int, jobs <-chan int, results chan<- int) {
    for j := range jobs {
        fmt.Println("worker", id, "started  job", j)
        time.Sleep(time.Second)
        fmt.Println("worker", id, "finished job", j)
        results <- j * 2
    }
}

func main() {
    jobs := make(chan int, 100)
    results := make(chan int, 100)
    for w := 1; w <= 3; w++ {
        go worker(w, jobs, results)
    }
    for j := 1; j <= 9; j++ {
        jobs <- j
    }
    close(jobs)
    for a := 1; a <= 9; a++ {
        <-results
    }
}
ログイン後にコピー

このコードでは、タスクを受信するチャネルとタスクの結果を返すチャネルの 2 つのチャネルを受け取るワーカー関数を定義します。 3つのゴルーチンを作成しましたが、それぞれのゴルーチンはジョブチャネルからタスクを取得し、処理結果を結果チャネルに書き込みます。最後に、for ループを使用して 9 つのタスクをジョブ チャネルに送信し、結果チャネルの値を標準出力に出力します。ワーカー関数を終了するには、for ループの後にジョブ チャネルを閉じる必要があることに注意してください。

2. 同期パッケージ

Golang では、同期パッケージは、次のような並列プログラミングに必要ないくつかの同期ツールを提供します:

· WaitGroup: Goroutine のグループが実行されるのを待ちます。タスクを完了する ;
· Mutex: 共有データへの相互排他的アクセスを実装します;
· Cond: 条件変数、複数の Goroutine 間で通信および同期します。

ここでは、WaitGroup の使用例を示します。

func worker(id int, wg *sync.WaitGroup) {
    defer wg.Done()
    fmt.Printf("Worker %d starting\n", id)

    time.Sleep(time.Second)
    fmt.Printf("Worker %d done\n", id)
}

func main() {
    var wg sync.WaitGroup

    for i := 1; i <= 5; i++ {
        wg.Add(1)
        go worker(i, &wg)
    }

    wg.Wait()
}
ログイン後にコピー

この例では、WaitGroup ポインターをパラメーターとして受け取るワーカー関数を定義します。関数の作業が完了したら、WaitGroup の Done メソッドを呼び出して、それが属する Goroutine タスクが完了したことを通知します。 main 関数では、ワーカー関数ごとに Goroutine を作成し、WaitGroup の Add メソッドを使用して、ここで実行されている Goroutine のグループがあることを WaitGroup に伝えます。最後に、Wait メソッドを呼び出して、すべてのゴルーチンがタスクを完了するのを待ちます。

3. GOMAXPROCS を設定する

Golang では、GOMAXPROCS は同時に実行する Goroutine の数を示す数値です。この数値の設定が小さすぎると、プログラムの並列処理が制限されます。設定が大きすぎると、コンピュータのリソースが無駄に消費されます。したがって、コンピューターのリソースの過剰な使用または過少使用を避けるために、コンピューターのプロセッサ コアの数に応じて GOMAXPROCS の値を設定する必要があります。

デフォルトでは、Golang の GOMAXPROCS はプロセッサ コアの数と同じです。ランタイム パッケージを使用してプログラム コード内で変更できます:

import "runtime"

//...

func main() {
    numCPU := runtime.NumCPU()
    runtime.GOMAXPROCS(numCPU)

    //...
}
ログイン後にコピー

ここでは、ランタイム パッケージを使用して次の値を取得します。プロセッサ コアの数を確認し、GOMAXPROCS の値をコアの数と同じに設定します。

概要

この記事では、Goroutine と Channel、Sync パッケージ、GOMAXPROCS の設定など、Golang での同時プログラミングのいくつかの方法とテクノロジを紹介します。同時プログラミングはプログラムのパフォーマンスと効率を向上させることができますが、いくつかのリスクと課題ももたらします。したがって、並行プログラミングを実行するときは、実際の状況に基づいて適切なソリューションを選択し、不要なエラーやリソースの無駄を避けるために並列度の制御に注意を払う必要があります。

以上がgolangの並列記述方法とは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Golangの目的:効率的でスケーラブルなシステムの構築 Golangの目的:効率的でスケーラブルなシステムの構築 Apr 09, 2025 pm 05:17 PM

GO言語は、効率的でスケーラブルなシステムの構築においてうまく機能します。その利点には次のものがあります。1。高性能:マシンコードにコンパイルされ、速度速度が速い。 2。同時プログラミング:ゴルチンとチャネルを介してマルチタスクを簡素化します。 3。シンプルさ:簡潔な構文、学習コストとメンテナンスコストの削減。 4。クロスプラットフォーム:クロスプラットフォームのコンパイル、簡単な展開をサポートします。

Golang and C:Concurrency vs. Raw Speed Golang and C:Concurrency vs. Raw Speed Apr 21, 2025 am 12:16 AM

Golangは並行性がCよりも優れていますが、Cは生の速度ではGolangよりも優れています。 1)Golangは、GoroutineとChannelを通じて効率的な並行性を達成します。これは、多数の同時タスクの処理に適しています。 2)Cコンパイラの最適化と標準ライブラリを介して、極端な最適化を必要とするアプリケーションに適したハードウェアに近い高性能を提供します。

Golangの影響:速度、効率、シンプルさ Golangの影響:速度、効率、シンプルさ Apr 14, 2025 am 12:11 AM

speed、効率、およびシンプル性をspeedsped.1)speed:gocompilesquilesquicklyandrunseffictient、理想的なlargeprojects.2)効率:等系dribribraryreducesexexternaldedenciess、開発効果を高める3)シンプルさ:

Golang vs. Python:パフォーマンスとスケーラビリティ Golang vs. Python:パフォーマンスとスケーラビリティ Apr 19, 2025 am 12:18 AM

Golangは、パフォーマンスとスケーラビリティの点でPythonよりも優れています。 1)Golangのコンピレーションタイプの特性と効率的な並行性モデルにより、高い並行性シナリオでうまく機能します。 2)Pythonは解釈された言語として、ゆっくりと実行されますが、Cythonなどのツールを介してパフォーマンスを最適化できます。

Golang vs. Python:重要な違​​いと類似点 Golang vs. Python:重要な違​​いと類似点 Apr 17, 2025 am 12:15 AM

GolangとPythonにはそれぞれ独自の利点があります。Golangは高性能と同時プログラミングに適していますが、PythonはデータサイエンスとWeb開発に適しています。 Golangは同時性モデルと効率的なパフォーマンスで知られていますが、Pythonは簡潔な構文とリッチライブラリエコシステムで知られています。

GolangとC:パフォーマンスのトレードオフ GolangとC:パフォーマンスのトレードオフ Apr 17, 2025 am 12:18 AM

GolangとCのパフォーマンスの違いは、主にメモリ管理、コンピレーションの最適化、ランタイム効率に反映されています。 1)Golangのゴミ収集メカニズムは便利ですが、パフォーマンスに影響を与える可能性があります。

パフォーマンスレース:ゴラン対c パフォーマンスレース:ゴラン対c Apr 16, 2025 am 12:07 AM

GolangとCにはそれぞれパフォーマンス競争において独自の利点があります。1)Golangは、高い並行性と迅速な発展に適しており、2)Cはより高いパフォーマンスと微細な制御を提供します。選択は、プロジェクトの要件とチームテクノロジースタックに基づいている必要があります。

CとGolang:パフォーマンスが重要な場合 CとGolang:パフォーマンスが重要な場合 Apr 13, 2025 am 12:11 AM

Cは、ハードウェアリソースと高性能の最適化が必要なシナリオにより適していますが、Golangは迅速な開発と高い並行性処理が必要なシナリオにより適しています。 1.Cの利点は、ハードウェア特性と高い最適化機能に近いものにあります。これは、ゲーム開発などの高性能ニーズに適しています。 2.Golangの利点は、その簡潔な構文と自然な並行性サポートにあり、これは高い並行性サービス開発に適しています。

See all articles