当前位置: 首页 > news >正文

家教网站建设的推广有网站开发经验怎么写简历

家教网站建设的推广,有网站开发经验怎么写简历,浏览器怎么打开网站,网络营销的工作岗位1. 什么是 Context#xff1f; Go 1.7 标准库引入 context#xff0c;中文译作“上下文”#xff0c;准确说它是 goroutine 的上下文#xff0c;包含 goroutine 的运行状态、环境、现场等信息。 context 主要用来在 goroutine 之间传递上下文信息#xff0c;包括#x…1. 什么是 Context Go 1.7 标准库引入 context中文译作“上下文”准确说它是 goroutine 的上下文包含 goroutine 的运行状态、环境、现场等信息。 context 主要用来在 goroutine 之间传递上下文信息包括取消信号、超时时间、截止时间、k-v 等。 Context也叫上下文它的接口定义如下 type Context interface {Deadline() (deadline time.Time, ok bool)Done() -chan struct{}Err() errorValue(key interface{}) interface{} }可以看到 Context 接口共有 4 个方法 Deadline返回的第一个值是截止时间到了这个时间点Context 会自动触发 Cancel 动作。返回的第二个值是 一个布尔值true 表示设置了截止时间false 表示没有设置截止时间如果没有设置截止时间就要手动调用 cancel 函数取消 Context。 Done返回一个只读的通道只有在被cancel后才会返回类型为 struct{}。当这个通道可读时意味着parent context已经发起了取消请求根据这个信号开发者就可以做一些清理动作退出goroutine。 Err返回 context 被 cancel 的原因。 Value返回被绑定到 Context 的值是一个键值对所以要通过一个Key才可以获取对应的值这个值一般是线程安全的。 2. 为什么要用Context 用于控制goroutine的结束但它解决的并不是 能不能 的问题而是解决 更好用 的问题。 2.1. 当不用Context时利用channelselect来主动让goroutine停止 示例1 package mainimport (fmttime )/* 1. 利用channel控制goroutine的停止 */func main() {stopChan : make(chan bool)go func() {for {select {case -stopChan:fmt.Println(goroutin1 exit.)returndefault:fmt.Println(goroutin1 sleep 1s, keep going.)time.Sleep(time.Second * 2)}}}()go func() {for {select {case -stopChan:fmt.Println(goroutin2 exit.)returndefault:fmt.Println(goroutin2 sleep 1s, keep going.)time.Sleep(time.Second * 3)}}}()time.Sleep(10 * time.Second)fmt.Println(10s 时间到了主进程需要退出了.)// 发送信号让goroute1结束stopChan - true// 发送信号让goroute2结束stopChan - truetime.Sleep(5 * time.Second) } 示例2 package mainimport (fmttime )/*1. 利用关闭channel的方法让2个goroutine同时结束 */func main() {stopChan : make(chan bool)go func() {for {select {case -stopChan:fmt.Println(goroutin1 exit.)returndefault:fmt.Println(goroutin1 sleep 1s, keep going.)time.Sleep(time.Second * 2)}}}()go func() {for {select {case -stopChan:fmt.Println(goroutin2 exit.)returndefault:fmt.Println(goroutin2 sleep 1s, keep going.)time.Sleep(time.Second * 3)}}}()time.Sleep(10 * time.Second)fmt.Println(10s 时间到了主进程需要退出了.)// 利用关闭channel的方法让2个goroutine同时结束close(stopChan)time.Sleep(5 * time.Second) } 2.2 使用context来主动让goroutine停止 先ctx, cancel : context.WithCancel(context.Background()) 创建一个ctx实例 再利用cancel()函数执行控制goroutine的停止 package mainimport (contextfmttime )/* // 利用context手动让2个goroutine同时结束[是不是更简单?] */ func main() {ctx, cancel : context.WithCancel(context.Background())go func() {for {select {case -ctx.Done():fmt.Println(goroutin1 exit.)returndefault:fmt.Println(goroutin1 sleep 1s, keep going.)time.Sleep(time.Second * 1)}}}()go func() {for {select {case -ctx.Done():fmt.Println(goroutin2 exit.)returndefault:fmt.Println(goroutin2 sleep 1s, keep going.)time.Sleep(time.Second * 1)}}}()time.Sleep(10 * time.Second)fmt.Println(10s 时间到了goroutine需要退出了.)// 利用context的方法手动让2个goroutine同时结束cancel()time.Sleep(5 * time.Second) } 2.3 使用context实现goroutine的超时控制 使用场景让goroutine执行一个任务如果在指定时间内没有完成这利用context的WithTimeout主动让goroutine退出 package mainimport (fmttimecontext )// 场景 如果你需要对一个用协程启动的函数做超时控制可以用context来完成goroutine的控制func main() {// 设置一个用于超时控制的context ctx, ctx作为参数可以用来作为协程的超时控制ctx,cancel : context.WithTimeout(context.Background(),10 * time.Second)defer cancel()// ctx作为参数传递给需要做超时控制的函数go Monitor(ctx)time.Sleep(20 * time.Second) }func Monitor(ctx context.Context) {for {select {// 如果context 超时ctx.Done()就会返回一个空接口 struct{}case - ctx.Done():// 如果超时时间到了就退出循环fmt.Println(ctx.Err())return// 如果没有超时打印输出后继续循环default:time.Sleep(1*time.Second)fmt.Println(monitor)}} }2.4 利用context向goroutine传递参数 除了超时控制与主动停止goroutine还有可以通过Context传递上下文变量给其他协程。这样可以避免在协程之间传递大量的变量代码更整洁可维护。下面的例子通过WithValue传递给协程一个变量并且通过channel在协程之间通信。 package mainimport (contextfmttime )func main() {// 为ctx设置一个key-valuectx : context.Background()ctx context.WithValue(ctx, hello, world)x : ctx.Value(hello)fmt.Println(x, x) // world// 将key-vluae值传递到goroutinego work(ctx)time.Sleep(3 * time.Second)} func work(ctx context.Context) {fmt.Println(do worker.)fmt.Println(hello, ctx.Value(hello)) // world利用context传递key-value// 继续传递到下层goroutinego subwork(ctx) }func subwork(ctx context.Context) {fmt.Println(do subwork.)fmt.Println(hello, ctx.Value(hello)) // world利用context传递key-value到更进一层 }程序输出 x world do worker. world do subwork. world
http://www.dnsts.com.cn/news/23711.html

相关文章:

  • 电商类网站开发合同书临沂画册设计公司
  • 全景图制作平台网站建设搜索引擎推广与优化
  • 淘宝客没网站怎么做做网站一定需要主机吗
  • 漯河做网站公司本地建wordpress
  • 上海市建设交通工会网站wordpress 行业模版
  • 衡水网站建设哪家专业电商网站设计制作
  • 商务网站制作语言基础德阳市建设局官方网站安全月
  • 广西网站开发软件网站收录怎么设置
  • 网站建设横向发展纵向发展seo超级外链
  • 海口网站制作策划关于微网站策划ppt怎么做
  • 做最好的在线看片网站企业信用中国官网
  • 网站网上推广网站开发师是做什么的
  • 钢板防护罩做网站the7做的网站
  • 网站内链的作用拒绝做网站的理由
  • 建网站找那家好长沙室内设计
  • 网站设配色哪里能做网站
  • 北京优秀的网站建设公司自建网站做淘宝联盟
  • 建设部门网站查询建一个网站花费
  • 网站规划的案例推广公众号有哪些方法
  • 网站建设资源分享软件外包公司如何接单
  • 陇南网站网站建设网站开发用几种字体
  • 秦皇岛网站制作报价网站关键词如何做
  • 中企动力网站后台服务专业制作网页
  • 网站制作和收费标准爱网站黄页
  • jsp简单的网站开发例子中国域名注册中心
  • 企业案例网站紧急域名升级更换通知
  • 大型的PC网站适合vue做吗wordpress主题修改导航链接
  • 职高动漫设计毕业后干什么网站推广优化价格
  • 图做的好的网站网站域名到期会怎么样
  • 网站多语言解决方案wordpress数据库重置