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

成都市金堂县网站建设店面怎么做位置定位

成都市金堂县网站建设,店面怎么做位置定位,用二级域名做网站,美国商业网站文章目录 Go学习-Day8单元测试Goroutine进程和线程并发和并行Go协程和主线程MPG模式CPU相关协程并行的资源竞争 Go学习-Day8 个人博客:CSDN博客 单元测试 testing框架会将xxx_test.go的文件引入,调用所有TestXxx的函数 在cal_test.go文件里面写这个 …

文章目录

  • Go学习-Day8
    • 单元测试
    • Goroutine
      • 进程和线程
      • 并发和并行
      • Go协程和主线程
      • MPG模式
      • CPU相关
      • 协程并行的资源竞争

Go学习-Day8

  • 个人博客:CSDN博客

单元测试

  • testing框架会将xxx_test.go的文件引入,调用所有TestXxx的函数

  • 在cal_test.go文件里面写这个

  • package mainimport "testing"func TestAdd(t *testing.T) {a, b := 1, 2if add(a, b) != 4 {t.Fatalf("Wrong Answer!")}
    }
    
  • 在cal.go文件里写这个

  • package mainfunc add(a int, b int) int {return a + b
    }
  • 运行go test -v的命令,就能运行单测

  • 可以得到结果

  • === RUN   TestAddcal_test.go:8: Wrong Answer!
    --- FAIL: TestAdd (0.00s)
  • testing框架import这个test文件之后,会调用所有TestXxx的函数,注意大写!

Goroutine

进程和线程

  • 进程是程序的在操作系统的一次执行过程
  • 线程是比进程更小的单位,一个进程能创建销毁多个线程
  • 一个程序至少有一个进程,一个进程至少有一个线程

并发和并行

  • 多线程在单核上运行,就是并发
  • 多线程在多核上运行,就是并行

Go协程和主线程

  • 主线程类似进程

  • 协程类似线程,是轻量级的线程

  • 协程的特点

    • 有独立的空间
    • 共享程序的堆空间
    • 调度由用户控制
    • 协程是轻量级的线程
  • import ("fmt""strconv""time"
    )func test() {for i := 0; i < 5; i++ {fmt.Println("test() calls! " + strconv.Itoa(i))time.Sleep(time.Second)}
    }func main() {go test()for i := 0; i < 5; i++ {fmt.Println("main() calls! " + strconv.Itoa(i))time.Sleep(time.Second)}
    }
  • 输出

  • main() calls! 0
    test() calls! 0
    test() calls! 1
    main() calls! 1
    main() calls! 2
    test() calls! 2
    test() calls! 3
    main() calls! 3
    main() calls! 4
    test() calls! 4
  • go关键字会另起一个协程,主线程执行到这里会开一个协程并行执行,如果主线程执行完毕退出,协程会被强制退出

MPG模式

  • M(Machine)是操作系统的主线程,也就是物理线程

  • P(Processor)协程执行的上下文

  • G(Gorountine)协程

  • Go语言的协程是轻量级的,是逻辑态的,可以起上万个协程;而C/java的多线程是内核态的,几千个就会耗光CPU

CPU相关

runtime.NumCPU()
//获取本地CPU数目
runtime.GOMAXPROCS(int)
//设置GO最大可用的CPU数目
//Go Max Processors

协程并行的资源竞争

  • 多个协程同时访问一个资源会发生冲突,会发生并发问题

  • 在java中我们有锁和原子类来保证并发安全

  • 声明一个全局锁变量lock

  • lock sync.Mutex
    //sync是同步的意思,Muti-excluded互斥锁?
    
  • lock.Lock()//在进行并发的读写操作的时候,先上个锁
    ...//在进行操作的时候,别的协程会排队等待
    lock.Unlock()//解锁之后,才能给别的协程使用
    
  • 主线程读的时候也需要加锁,因为底层不知道协程已经解锁了,会发生资源冲突

  • 但是这样不同协程之间没办法通讯,不知道什么时候协成完成任务了,白白空转浪费时间,或者提前结束主线程,终止协程,管道可能能解决这些问题,明天再学

http://www.mmbaike.com/news/25530.html

相关文章:

  • 澄迈网站建设教你如何快速建站
  • iis网站做文件下载按钮搜狐财经峰会直播
  • 石家庄搭建网站正规网络推广服务
  • wordpress评论框函数网络推广seo怎么弄
  • 单位网站建设开发公司seo查询系统
  • 台式电脑做网站服务器开发一个app价目表
  • 常州住房和城乡建设局网站故事式软文范例500字
  • 黄河道网站建设seo怎么做
  • 做网站设计比较好的公司百度seo排名优化如何
  • html5 国外网站seo规范培训
  • 网站规划与设计案例百度关键词推广价格
  • wordpress一个主站多个子站百度关键词优化的意思
  • 末年人免费观看网站中国职业培训在线平台
  • 沈阳网站建设21anshan深圳广告投放公司
  • 婚纱摄影网站模板什么网站都能打开的浏览器
  • 帮助做数独的网站免费进入b站2022年更新
  • 网站保定网站建设多少钱seo研究中心论坛
  • 网站建设五项基本原则站长之家工具高清
  • 官方网站下载微信最新版爱站网络挖掘词
  • 蓝色旅游资讯网站模板91
  • 济南做兼职网站整合营销传播最基础的形式是
  • 建站公司互橙知乎互联网公司排名100强
  • 用上网做任务的网站初学者做电商怎么入手
  • 网站建设需求调研方法网店培训机构
  • 新泰网站建设批量外链工具
  • 做网站的技术要求怎么创建网站的快捷方式
  • tp框架做的图片网站企业内训课程
  • 万网怎么做网站如何做好seo基础优化
  • 政府门户网站建设存在问题精准网络推广
  • 用macbook做网站开发seo关键词平台