9.4.17.1 توضیحات #
الگوی “صف” در زبان گو الگویی است که در آن از یک گوروتین برای بافر کردن و مدیریت ترتیب مقادیر ارسال شده و دریافت شده از یک کانال استفاده می شود.
9.4.17.2 دیاگرام #
flowchart TD
A[شروع] --> B[تولیدکنندهها]
B -->|افزودن درخواستها| C[صف درخواستها]
C -->|ارسال به مصرفکننده| D[مصرفکنندهها]
D --> E[پردازش درخواستها]
E --> F[پایان]
9.4.17.3 نمونه کد #
1package main
2
3import "fmt"
4
5func main() {
6 // Declare the queue channel with a buffer size of 5
7 queue := make(chan int, 5)
8
9 // Send values to the queue
10 go func() {
11 for i := 0; i < 10; i++ {
12 queue <- i
13 fmt.Println("Sent:", i)
14 }
15 close(queue)
16 }()
17
18 // Receive values from the queue
19 for value := range queue {
20 fmt.Println("Received:", value)
21 }
22}
1$ go run main.go
2Sent: 0
3Received: 0
4Received: 1
5Sent: 1
6Sent: 2
7Sent: 3
8Sent: 4
9Sent: 5
10Sent: 6
11Sent: 7
12Received: 2
13Received: 3
14Received: 4
15Received: 5
16Received: 6
17Received: 7
18Received: 8
19Sent: 8
20Sent: 9
21Received: 9
در کد فوق ما یک کانال بافر شده با ظرفیت ۵ ایجاد کردیم. سپس داخل یک گوروتین یک حلقه قرار داده از i تا ۱۰ و مقدار i را به کانال فرستادیم و در نهایت کانال را بستیم. سپس یکی حلقه for-range برروی کانال قرار دادیم و مقادیر را دریافت کردیم و سپس چاپ کردیم.
9.4.17.4 کاربردها #
- زمانبندی کار (Task scheduling): یک کانال میتواند به عنوان صف برای نگهداشتن وظایفی که باید توسط یک گوروتین worker اجرا و استفاده شود. کارگر وظایف را به ترتیبی که اضافه شده اند از صف می گیرد و آنها را پردازش می کند.
- بافر کردن داده ها: یک کانال می تواند به عنوان یک بافر برای نگهداری داده های ورودی قبل از پردازش توسط گوروتین دیگر استفاده شود. این می تواند زمانی مفید باشد که سرعت پردازش داده ها کندتر از سرعت دریافت آن باشد.
- Throttling: یک کانال می تواند به عنوان یک صف برای محدود کردن سرعت پردازش داده ها توسط یک گوروتین استفاده شود. با افزودن یک بافر به کانال، زمانی که بافر پر شود، گوروتین ارسال کننده مسدود می شود و به طور موثر سرعت ارسال داده ها را کاهش می دهد.
- Logging: یک کانال می تواند به عنوان یک صف برای نگهداری پیام های گزارشی که باید در یک فایل نوشته شود یا از طریق شبکه ارسال شود استفاده شود. کارگر گوروتین پیامهای گزارش را به ترتیبی که اضافه شدهاند از صف میگیرد و در فایل گزارش مینویسد.
- Multi-threading: یک کانال می تواند به عنوان یک صف برای به اشتراک گذاری داده ها بین گوروتین های مختلف و مدیریت همزمانی برنامه استفاده شود.