每日一抄 Go语言关闭通道后继续使用
package main
import "fmt"
/*
通道是一个引用对象,和 map 类似。map 在没有任何外部引用时,
Go语言程序在运行时(runtime)会自动对内存进行垃圾回收(Garbage Collection, GC)。类似的,
通道也可以被垃圾回收,但是通道也可以被主动关闭。
*/
/*
格式:
使用close来关闭一个通道
close(ch)
关闭的通道依然可以被访问,访问被关闭的通道将会发生一些问题
*/
/*
给被关闭通道发送数据将会触发panic
被关闭的通道不会被置位nil。如果尝试对已经关闭的通道进行发送,将会触发宕机,代码如下
*/
func main() {
	//创建一个整形通道
	ch := make(chan int, 1)
	//关闭通道
	close(ch)
	//go func(ch chan int) {
	//	select {
	//	case a := <-ch:
	//		fmt.Println(a)
	//	}
	//}(ch)
	ch <- 1
	fmt.Printf("ptr:%p cap:%d len:%d\n", ch, cap(ch), len(ch))
	a := <-ch
	fmt.Println(a)
}
已关闭的通道可以读取数据
package main
import "fmt"
/*
通道是一个引用对象,和 map 类似。map 在没有任何外部引用时,
Go语言程序在运行时(runtime)会自动对内存进行垃圾回收(Garbage Collection, GC)。类似的,
通道也可以被垃圾回收,但是通道也可以被主动关闭。
*/
/*
格式:
使用close来关闭一个通道
close(ch)
关闭的通道依然可以被访问,访问被关闭的通道将会发生一些问题
*/
/*
给被关闭通道发送数据将会触发panic
被关闭的通道不会被置位nil。如果尝试对已经关闭的通道进行发送,将会触发宕机,代码如下
*/
func main() {
	//创建一个整形通道
	ch := make(chan int, 1)
	ch <- 2
	//关闭通道
	close(ch)
	//go func(ch chan int) {
	//	select {
	//	case a := <-ch:
	//		fmt.Println(a)
	//	}
	//}(ch)
	fmt.Printf("ptr:%p cap:%d len:%d\n", ch, cap(ch), len(ch))
	a := <-ch
	fmt.Println(a)
}
本文来自博客园,作者:蹇爱黄,转载请注明原文链接:https://www.cnblogs.com/jianjiana/p/16944291.html
 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号