- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - phát hiện rò rỉ bộ nhớ Ruby/Ruby on Rails
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我很好奇为什么以下不起作用。一般lựa chọn
sử dụngmặc định:
防止死锁,但在这种情况下不是:
gói chính
nhập khẩu "fmt"
hàm main () {
a := make(chan int)
b := make(chan int)
lựa chọn {
case a <- <- b:
fmt.Println("this is impossible")
mặc định:
fmt.Println("select worked as naively expected")
}
}
显然它不喜欢 <- <-
但我想知道这里的表面背后发生了什么。其他情况<- <-
是允许的(尽管可能不推荐)。
câu trả lời hay nhất
a <- <- b
Vàa<- (<-b)
相同,因为 <-
运算符与最左边的 chan
关联可能。
Vì thế lựa chọn
有一个 trường hợp
使用发送操作(以 a<- (something)
的形式)。这里发生的是发送语句的右侧表达式(要发送的值)首先被评估 - 这是 <-b
.但这将永远阻塞(因为没有人在 b
上发送任何东西),所以:
fatal error: all goroutines are asleep - deadlock!
相关部分形成Spec: Select statements:
Execution of a "select" statement proceeds in several steps:
For all the cases in the statement, the channel operands of receive operations and the channel and right-hand-side expressions of send statements are evaluated exactly once, in source order, upon entering the "select" statement. The result is a set of channels to receive from or send to, and the corresponding values to send. Any side effects in that evaluation will occur irrespective of which (if any) communication operation is selected to proceed. Expressions on the left-hand side of a RecvStmt with a short variable declaration or assignment are not yet evaluated.
If one or more of the communications can proceed, a single one that can proceed is chosen via a uniform pseudo-random selection. Otherwise, if there is a default case, that case is chosen. If there is no default case, the "select" statement blocks until at least one of the communications can proceed.
...
所以如果mặc định
存在,lựa chọn
如果在Bước 2 中无法进行任何通信,但您的代码会卡在Bước 1 中,则确实会阻止阻塞。
只是为了完整,如果有一个 goroutine 会在 b
上发送一个值, 然后评估 <- b
不会阻塞,所以执行 lựa chọn
不会卡在第 2 步,您会看到预期的 "select worked as naively expected"
(因为从 Một
接收仍然无法继续,因此将选择 mặc định
):
go func() { b <- 1 }()
lựa chọn {
// ...
}
hiện hữu Đi đến Sân chơi 上试试.
关于选择 channel <- <- channel ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35615326/
Có cách nào để thể hiện loại SQL này bằng API JPA hoặc Hibernate Crtiteria không? Hay tôi nên làm điều đó như người bản xứ? CHỌN AX TỪ (CHỌN X,
Trong truy vấn, chọn id,name,feature,marks from (....) Tôi muốn xóa những cái có id tồn tại trong một câu lệnh chọn khác. Chọn id từ (...) Tôi là sql
Tôi muốn phản hồi người dùng chọn một mục trong phần tử được chọn. Tuy nhiên jQuery này: $('#platypusDropDown').select(function () { Alert('You sel
Câu hỏi này đã có câu trả lời ở đây: SQL chỉ chọn các hàng có giá trị tối đa trên một cột [trùng lặp] (27 câu trả lời) Đã đóng 8 năm trước. Tôi đang học SQL
Câu hỏi này đã có câu trả lời ở đây: “Lưu ý: Biến không xác định”, “Lưu ý: Chỉ mục không xác định” và
Tôi đang gọi SQL bằng tập lệnh php. Đôi khi không có giá trị trong "DE", nếu đó là trường hợp tôi muốn lấy giá trị từ "EN" thì nó phải như thế này, nhưng không phải như thế này IF (EXISTS (SELECT epf_application_deta
Đây có thể là một câu hỏi lạ nhưng chưa biết cách nghiên cứu. Khi thực hiện truy vấn sau: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
Cách chọn hoặc nhận nhiều hình ảnh cùng lúc trong API camera phonegap trong khi sử dụng Camera.DestinationType.FILE_URI. Tôi chỉ có thể chọn một hình ảnh mỗi lần. Tôi có thể sử dụng cái này trong
Đây là một câu hỏi thuần túy học thuật. Hai tuyên bố này có thực sự giống nhau không? IF EXISTS (CHỌN TOP 1 1 TỪ Bảng1) CHỌN 1 ELSE CHỌN 0 liên quan đến IF EXIS
Tôi đang sử dụng JSoup để phân tích phản hồi HTML. Tôi có nhiều thẻ Div. Tôi phải chọn thẻ Div dựa trên ID. Mã giả của tôi giống như thế này Document divTag = Jsoup.connect(link
Tôi đang làm việc trên một biểu mẫu có nhiều hộp chọn. Tôi cần một giá trị khác cho selectbox2 hoạt động khi người dùng chọn một tùy chọn từ selectbox1. Tương tự như vậy khi anh ấy chọn một giá trị khác của selectbox2 tôi cần
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
Tôi có một login.html trong đó biểu mẫu được xác định như sau: Tên viết tắt cộng với Họ: do_authorize của tôi như sau: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', hàm(dữ liệu
Tôi có danh sách thả xuống gồm "cân", "gam", "kilôgam" và "ounce". Tôi muốn một tình huống khi tôi chọn gram để thực thi một hàm khi tôi nhập một giá trị vào trường đầu vào và khi tôi chọn pound, tôi muốn một hàm khác thực thi khi tôi nhập
Tôi có trình đổ bóng GLSL đọc từ một trong các kênh của kết cấu đầu vào (ví dụ: R) và ghi vào cùng một kênh trong kết cấu đầu ra. Kênh phải được người dùng lựa chọn. Tất cả những gì tôi có thể nghĩ ra lúc này là sử dụng int
Tôi muốn tạo hộp văn bản đầu vào dựa trên giá trị đã chọn trong danh sách thả xuống. Tùy chọn 2 3 4 5 Ngay sau hộp chọn này, một số trường nhập sẽ xuất hiện theo số đã chọn. Câu trả lời hay nhất tôi khuyên bạn nên sử dụng phản ứng (Reac
Tôi chưa quen với SQL và tôi muốn hỏi cách chọn các mục dựa trên tùy chọn và nhóm. +----------+----------+------+ | ENTRY_ID |
Tôi có cấu trúc bảng sau: TẠO BẢNG [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
Tôi gặp sự cố khi loại bỏ các trang không cần thiết. Tôi đã xem các diễn đàn khác nhau và kết hợp các giải pháp khác nhau. Macro này xóa các bảng tính (ngoại trừ bảng tính đầu tiên). Sub sai() Dim sht As Object Applicati
Tôi là một lập trình viên xuất sắc, rất giỏi!