mirror of
				https://github.com/golang/go.git
				synced 2025-10-31 08:40:55 +00:00 
			
		
		
		
	 7839521335
			
		
	
	
		7839521335
		
	
	
	
	
		
			
			*** Reason for rollback *** roll back the changes to the tutorial programs (only) since they break the automated processing used to create the tutorial. *** Original change description *** apply gofmt to the LGTM-marked files from 34501 that have not changed since I applied gofmt. R=rsc DELTA=139 (0 added, 44 deleted, 95 changed) OCL=35670 CL=35670
		
			
				
	
	
		
			38 lines
		
	
	
	
		
			910 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
	
		
			910 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2009 The Go Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package main
 | |
| 
 | |
| import "fmt"
 | |
| 
 | |
| // Send the sequence 2, 3, 4, ... to channel 'ch'.
 | |
| func generate(ch chan int) {
 | |
| 	for i := 2; ; i++ {
 | |
| 		ch <- i  // Send 'i' to channel 'ch'.
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Copy the values from channel 'in' to channel 'out',
 | |
| // removing those divisible by 'prime'.
 | |
| func filter(in, out chan int, prime int) {
 | |
| 	for {
 | |
| 		i := <-in;  // Receive value of new variable 'i' from 'in'.
 | |
| 		if i % prime != 0 {
 | |
| 			out <- i  // Send 'i' to channel 'out'.
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // The prime sieve: Daisy-chain filter processes together.
 | |
| func main() {
 | |
| 	ch := make(chan int);  // Create a new channel.
 | |
| 	go generate(ch);  // Start generate() as a goroutine.
 | |
| 	for {
 | |
| 		prime := <-ch;
 | |
| 		fmt.Println(prime);
 | |
| 		ch1 := make(chan int);
 | |
| 		go filter(ch, ch1, prime);
 | |
| 		ch = ch1
 | |
| 	}
 | |
| }
 |