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

一步一步教你做网站后台视频app推广公司怎么对接业务

一步一步教你做网站后台视频,app推广公司怎么对接业务,前端低代码平台开发,wordpress影视模板题目 使用 Go 语言统计 0-200000的数字中,哪些是素数? 思路 两种方法: 单循环遍历 1-200000 数字,并判断是否是素数。 使用了 Goroutine 和通道实现并发: 通过创建两个通道 intChan 和 primeChan,以及一…

题目

使用 Go 语言统计 0-200000的数字中,哪些是素数?

思路

两种方法:

  1. 单循环遍历 1-200000 数字,并判断是否是素数。

  2. 使用了 Goroutine 和通道实现并发:

    • 通过创建两个通道 intChanprimeChan,以及一个 sync.WaitGroup 来协调 Goroutine 的执行。

    • 然后,启动三个 Goroutine:

      • InputIntChan:向 intChan 通道中写入整数数据。
      • PrimeCompute:从 intChan 通道中读取整数数据,并判断是否为素数,将素数写入 primeChan 通道。
      • readPrimeChan:从 primeChan 通道中读取素数数据并输出。

      最后,使用 sync.WaitGroup 等待所有 Goroutine 执行完毕。

代码实现

单循环实现

package mainimport ("fmt""math""time"
)func main() {start := time.Now().Unix() // 记录开始时间primeChan := make(chan int, 2000000) // 创建一个缓冲大小为2000000的素数通道for i := 0; i <= 200000; i++ { // 判断从0到200000的整数是否为素数if isPrime(i) { // 如果是素数primeChan <- i // 写入素数通道}}end := time.Now().Unix() // 记录结束时间fmt.Println("总耗时时间:", end-start) // 输出总耗时时间
}// 判断一个整数是否为素数
func isPrime(n int) bool {if n <= 1 {return false}for i := 2; i <= int(math.Sqrt(float64(n))); i++ { // 只需遍历到sqrt(n)即可,减少计算量if n%i == 0 {return false}}return true
}

Goroutine 和通道实现

好的,以下是给代码加上注释后的版本:

package mainimport ("fmt""math""strconv""sync"
)func main() {var wg sync.WaitGroupwg.Add(3)intChan := make(chan int, 1000)      // 创建一个缓冲大小为1000的整数型通道primeChan := make(chan int, 2000000) // 创建一个缓冲大小为2000000的整数型通道go InputIntChan(intChan, &wg) // 启动写入整数的协程go PrimeCompute(intChan, primeChan, &wg) // 启动计算素数并写入素数通道的协程go readIntChan(primeChan, &wg) // 启动读取素数并输出的协程wg.Wait() // 等待所有协程结束
}// 判断一个整数是否为素数
func isPrime(n int) bool {if n <= 1 {return false}for i := 2; i <= int(math.Sqrt(float64(n))); i++ { // 只需遍历到sqrt(n)即可,减少计算量if n%i == 0 {return false}}return true
}// 往通道中写入整数
func InputIntChan(intChan chan<- int, wg *sync.WaitGroup) {for i := 0; i <= 200000; i++ { // 写入200000个整数intChan <- i // 写入整数通道fmt.Println("写入Int通道==" + strconv.Itoa(i))}close(intChan) // 写入完成,关闭通道wg.Done()      // 协程结束,减少计数器
}// 判断整数是否为素数,并往素数通道中写入素数
func PrimeCompute(intChan <-chan int, primeChan chan<- int, wg *sync.WaitGroup) {for i := range intChan { // 循环判断每个整数是否为素数if isPrime(i) {primeChan <- i // 如果是素数,往素数通道中写入素数}}close(primeChan) // 计算完毕,关闭素数通道wg.Done()        // 协程结束,减少计数器
}// 从素数通道中读取素数并输出
func readIntChan(primeChan <-chan int, wg *sync.WaitGroup) {for i := range primeChan { // 循环读取素数通道中的素数fmt.Println("从通道中读取素数==" + strconv.Itoa(i))}wg.Done() // 协程结束,减少计数器
}

优化思路

创造多个协程处理写入读取通道

http://www.bjxfkj.com.cn/article/100211.html

相关文章:

  • 网站营销推广计划书文案发布平台
  • 建站优化信息推广宁波seo怎么做推广渠道
  • 做网站都需要哪些费用深圳网络公司推广公司
  • 公司制做网站seo招聘
  • wordpress找不到xml南宁优化网站网络服务
  • php制作网页文章优化关键词排名
  • 做网站需要写程序关键词排名怎么查
  • 建公司网站报价seo关键词排名优化技巧
  • css做网站产品推广的渠道有哪些
  • 网站的建设论文定制网站多少钱
  • 大型做网站的公司有哪些东营优化路网
  • 在阿里云做网站教程深圳网站建设服务
  • 江苏科技大学新校区建设网站站长之家 seo查询
  • 橙子建站验证码我输了咋办seo的基本步骤是什么
  • wordpress 多模板黑帽seo排名技术
  • 08r2 搭建php网站百度关键词搜索引擎
  • 外贸网站使用什么品牌国外主机最新疫情最新消息
  • 莆田企业自助建站系统微信管理助手
  • 第一次和别人女友做网站百度竞价推广账户优化
  • 用帝国做的网站成都网站推广公司
  • 营销型网站建设指导原则百度账号设置
  • 做b2c商城网站网络推广公司如何做
  • 营销型企业网站建设流程汕头网站优化
  • 合肥网站建站百度账号登录个人中心
  • 怎样直接输入网址打开网站百度百度一下百度
  • 蚂蜂窝网站分析事件营销案例
  • 慈溪怎么做网站seo长尾关键词
  • 网站平台客服系统腾讯朋友圈广告怎么投放
  • 组织建设 湖南省直工会网站上海关键词排名搜索
  • 公司网站建设手续制作网站软件