Golang 과 python 스 레 드 상세 설명 및 간단 한 인 스 턴 스
GO 에서 15 개의 스 레 드 를 열 고 스 레 드 마다 전체 변 수 를 100000 회 증가 시 킵 니 다.따라서 예측 결 과 는 15*100000=150000 입 니 다.
var sum int
var cccc int
var m *sync.Mutex
func Count1(i int, ch chan int) {
for j := 0; j < 100000; j++ {
cccc = cccc + 1
}
ch <- cccc
}
func main() {
m = new(sync.Mutex)
ch := make(chan int, 15)
for i := 0; i < 15; i++ {
go Count1(i, ch)
}
for i := 0; i < 15; i++ {
select {
case msg := <-ch:
fmt.Println(msg)
}
}
}
하지만 최종 결 과 는 406527자물쇠 가 필요 하 다 는 뜻 입 니 다.
func Count1(i int, ch chan int) {
m.Lock()
for j := 0; j < 100000; j++ {
cccc = cccc + 1
}
ch <- cccc
m.Unlock()
}
최종 출력:1500000python 에서:같은 방식 으로 이 루어 져 도 안 됩 니 다.
count = 0
def sumCount(temp):
global count
for i in range(temp):
count = count + 1
li = []
for i in range(15):
th = threading.Thread(target=sumCount, args=(1000000,))
th.start()
li.append(th)
for i in li:
i.join()
print(count)
출력 결과:3004737설명 에 도 자 물 쇠 를 추가 해 야 합 니 다.
mutex = threading.Lock()
count = 0
def sumCount(temp):
global count
mutex.acquire()
for i in range(temp):
count = count + 1
mutex.release()
li = []
for i in range(15):
th = threading.Thread(target=sumCount, args=(1000000,))
th.start()
li.append(th)
for i in li:
i.join()
print(count)
출력 1500000OK,자 물 쇠 를 넣 은 작은 열.
읽 어 주 셔 서 감사합니다. 여러분 에 게 도움 이 되 기 를 바 랍 니 다.본 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Golang 구현 대기열 및 스택대기열: 스택: github 주소:https://github.com/golibec/Lstruct.git 후속적으로 각종 데이터 구조와 주류 알고리즘을 지속적으로 보완할 것이다....
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.