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

可以做推文的网站做网站网页挣钱不

可以做推文的网站,做网站网页挣钱不,wordpress 加斜杠,广州市网站建设怎么样概述 在上一节的内容中#xff0c;我们介绍了Go的类型转换#xff0c;包括#xff1a;断言类型转换、显式类型转换、隐式类型转换、strconv包等。在本节中#xff0c;我们将介绍Go的并发。Go语言以其强大的并发模型而闻名#xff0c;其并发特性主要通过以下几个元素来实现…概述 在上一节的内容中我们介绍了Go的类型转换包括断言类型转换、显式类型转换、隐式类型转换、strconv包等。在本节中我们将介绍Go的并发。Go语言以其强大的并发模型而闻名其并发特性主要通过以下几个元素来实现Goroutines、Channels、WaitGroups、Mutex和Select。通过结合使用以上元素Go语言提供了强大的并发支持使得编写高效、高性能、高吞吐量的并发程序变得相对容易。 Goroutines Goroutines是Go语言中轻量级的并发单元可以与其他goroutine并发执行。它们在相同的地址空间内运行但每个goroutine都有自己的栈和局部变量。Goroutine的启动和销毁开销很小使得在程序中可以创建大量的Goroutine。相比于线程Goroutine的创建和管理成本更低因为它们不需要像线程一样分配固定的内存空间。此外Goroutine之间可以通过Channels进行通信避免使用共享内存和信号量等机制从而避免了竞态条件和数据竞争等问题。 Goroutine是Go语言的主要并发原语通常用于实现高并发的应用程序。Go运行时将Goroutine有效地调度到真实的线程上以避免浪费资源。因此可以轻松地创建大量的Goroutine比如每个请求一个Goroutine并且可以编写简单的、命令式的阻塞代码。 Goroutine的语法格式为 go func_name(arguments) 其中go关键字表示启动一个新的Goroutinefunc_name表示要启动的函数名arguments表示传递给函数的参数列表。通过在函数调用前加上go关键字可以启动一个新的Goroutine来执行该函数。这个Goroutine将与其他Goroutine并发执行并且不需要显式地创建和管理线程。 在下面的示例代码中我们使用go关键字启动了两个Goroutine来执行printMsg函数。每个Goroutine都会打印出相应的消息并且通过time.Sleep函数来模拟一些耗时的操作。主Goroutine在启动了其他两个Goroutine之后会等待一段时间以确保所有Goroutine都有足够的时间来执行完毕。 package mainimport (fmttime )func main() {// 启动第1个Goroutinego printMsg(Hello)// 启动第2个Goroutinego printMsg(CSDN)// 等待一段时间以确保所有Goroutine执行完毕time.Sleep(time.Second) }func printMsg(msg string) {for i : 0; i 5; i {fmt.Println(msg)// 模拟耗时的操作time.Sleep(200 * time.Millisecond)} } 注意Goroutine之间的执行顺序是不确定的因此每次运行程序都会得到不同的输出结果这取决于Go运行时调度器的实现细节和系统负载等因素。 Channels Channels是一种通信机制用于在goroutines之间进行数据传输和同步操作。Channels支持发送和接收操作并且可以在发送和接收操作之间进行阻塞以实现同步。Channels的使用非常灵活可以根据需要进行单向或双向数据传输。它们可以用于在不同的goroutines之间传递数据以及实现数据共享。 在创建Channels时可以指定其缓冲区大小缓冲区的大小决定了可以存储在Channels中的数据量。如果空闲缓冲区为空发送操作会被阻塞直到有接收操作。如果空闲缓冲区已满接收操作会被阻塞直到有发送操作。这种机制可以实现数据在goroutines之间的有效传输和同步。 注意不同类型的Channel有不同的性能和用途。无缓冲的Channel即缓冲区大小为0可以在发送和接收操作之间进行同步而有缓冲的Channel可以提高并发性能但需要小心处理缓冲区溢出的问题。 Channel的语法格式为 chan type 其中type表示Channel中传输的数据类型。比如chan int表示一个用于传输整数类型的Channel。除了指定数据类型之外还可以使用chan来创建具有不同缓冲区大小的Channel。比如chan int buffer(10)表示创建一个缓冲区大小为10的整数类型Channel。 除了使用chan来创建Channel之外还可以使用内置的make函数来创建具有指定类型的Channel。比如make(chan int)表示创建一个整数类型的无缓冲Channel。 在使用Channel时可以使用以下操作进行数据传输和同步。 x : -ch从Channel中接收数据并将接收到的数据赋值给变量x。 ch - x向Channel中发送数据并将变量x的值发送到Channel中。 如果Channel被阻塞则接收操作将阻塞直到有数据可用。如果发送操作导致缓冲区已满则发送操作将阻塞直到有空间可用。 在下面的示例代码中我们将数组分为两个切片并通过两个goroutine来计算切片之和。在goroutine完成计算并将切片之和发送到通道后main函数会从通道中接收数据并计算最终的总和。 package mainimport fmtfunc sum(s []int, c chan int) {total : 0for _, v : range s {total v}// 把total发送到通道c - total }func main() {data : []int{1, 2, 3, 4, 5, 6}c : make(chan int)offset : len(data) / 2go sum(data[:offset], c)go sum(data[offset:], c)// 从通道中接收结果x, y : -c, -c// 输出15 6 21 或 6 15 21fmt.Println(x, y, x y) } 除了逐个接收数据之外还可以通过range关键字来遍历读取到的数据。注意使用range遍历时需要确保发送完数据后及时调用close()函数来关闭通道。否则range遍历不会结束会一直阻塞等待接收新的数据。 在下面的示例代码中我们首先使用make函数创建了一个整数类型的Channel。然后我们启动一个匿名的Goroutine来循环发送数字10至50到Channel中并在发送完毕后关闭Channel。最后我们在主Goroutine中使用range关键字来迭代接收Channel中的数据并将其打印输出。 通过调用close函数可关闭一个Channel关闭Channel表示再也不会向该Channel发送任何数据。对于已经发送到Channel中的数据仍然可以被接收。由于Channel已经被关闭迭代接收数据将自动停止。 package mainimport fmtfunc main() {// 创建一个整数类型的Channelch : make(chan int)// 启动一个Goroutinego func() {for i : 10; i 50; i 10 {// 发送数据到Channelch - ifmt.Println(sub routine:, i)}// 关闭Channelclose(ch)}() // 从Channel接收数据依次输出10 20 30 40 50for num : range ch {fmt.Println(num)} } WaitGroups 在Go语言中WaitGroups是sync包中的一个类型用于等待一组Goroutine执行完成。它提供了一种方便的方式以确保所有的Goroutine都执行完毕后再继续执行后续的逻辑。 WaitGroups的使用比较简单首先需要创建一个WaitGroups实例然后通过调用Add()函数增加等待的Goroutine数量每个Goroutine执行完毕后要调用Done()函数进行计数减一最后在主Goroutine中调用Wait()函数来等待所有的Goroutine都执行完毕。 在下面的示例代码中我们创建了一个WaitGroups实例wg然后通过调用Add()函数增加了两个Goroutine。每个Goroutine中使用defer语句调用Done()函数来标记该Goroutine的执行完成。最后在主Goroutine中调用Wait()函数来等待所有的Goroutine都执行完毕然后继续执行后续的逻辑。 package mainimport fmt import sync import timefunc main() {var wg sync.WaitGroup// 启动第一个Goroutinewg.Add(1)go func() {defer wg.Done()fmt.Println(Goroutine 1 started)time.Sleep(1 * time.Second)fmt.Println(Goroutine 1 finished)}()// 启动第二个Goroutinewg.Add(1)go func() {defer wg.Done()fmt.Println(Goroutine 2 started)time.Sleep(2 * time.Second)fmt.Println(Goroutine 2 finished)}()// 等待所有Goroutine执行完毕wg.Wait()// 所有Goroutine执行完毕后继续执行后续逻辑fmt.Println(All Goroutines finished) } Mutex 在Go语言中mutex是一种用于实现并发安全的锁机制。它提供了一种简单的方式来保护共享资源以避免多个Goroutine同时访问和修改数据从而导致竞争条件或数据不一致的问题。mutex通常是通过sync.Mutex类型来实现的这个类型提供了两个函数Lock和Unlock。 在下面的示例代码中我们定义了一个全局变量counter和一个sync.Mutex类型的变量mutex。在increment函数中我们使用mutex.Lock()来锁定mutex以确保在同一时间只有一个Goroutine可以访问和修改counter。在完成对counter的修改后使用defer mutex.Unlock()来解锁mutex以确保在函数返回之前释放锁从而允许其他Goroutine获取锁并访问共享资源。最后在主函数中我们启动了5个并发的Goroutine来增加计数器的值并等待一段时间后打印最终的计数结果。 package mainimport fmt import sync import timevar (counter intmutex sync.Mutex ) func increment() {// 锁定mutex确保同一时间只有一个Goroutine可以访问和修改countermutex.Lock()defer mutex.Unlock()// 增加计数器的值fmt.Println(Current counter:, counter)counter }func main() {// 启动5个并发的Goroutine来增加计数器的值for i : 0; i 5; i {go increment()}// 等待所有Goroutine执行完毕time.Sleep(time.Second)fmt.Println(Final counter:, counter) } Select select语句用于在多个通道操作之间进行选择它允许你等待多个通道操作中的任意一个完成然后执行对应的代码块。其语法如下 select { case -channel1:// 执行channel1操作完成的代码块 case -channel2:// 执行channel2操作完成的代码块 case -channel3:// 执行channel3操作完成的代码块 default:// 如果没有任何通道操作完成执行default代码块 } 在select语句中每个case子句必须是一个通道操作。当其中一个通道操作完成时对应的代码块将被执行。如果没有任何通道操作完成且存在default子句则执行default代码块。 在下面的示例代码中我们创建了三个通道并使用三个Goroutine分别向这三个通道发送消息。然后在select语句中等待哪个通道先完成操作并打印收到的消息。由于发送消息的Goroutine使用了不同的延迟时间因此最终打印的消息取决于哪个通道最先完成操作。 package mainimport fmt import timefunc func1(channel1 chan string) {time.Sleep(1 * time.Second)channel1 - Channel 1 }func func2(channel2 chan string) {time.Sleep(2 * time.Second)channel2 - Channel 2 }func func3(channel3 chan string) {time.Sleep(3 * time.Second)channel3 - Channel 3 }func main() { channel1 : make(chan string)channel2 : make(chan string)channel3 : make(chan string)go func1(channel1)go func2(channel2)go func3(channel3)select {case msg1 : -channel1:fmt.Println(Received from Channel 1:, msg1)case msg2 : -channel2:fmt.Println(Received from Channel 2:, msg2)case msg3 : -channel3:fmt.Println(Received from Channel 3:, msg3)} }
http://www.yingshimen.cn/news/97148/

相关文章:

  • 足球队世界排名榜西安百度网站快速优化
  • 南沙哪有做网站的眉山市做网站的公司
  • 网站建设 广温州网站建设和推广
  • 美食网站首页模板邮箱企业邮箱登录入口
  • 怎么用polylang做网站沧州网站建设微艾薇
  • wordpress定义小工具栏深圳市seo上词贵不贵
  • 国内php开发的电商网站有哪些平面设计软件哪个好
  • 亚马逊网站怎么做推广wordpress 时间轴主题
  • 网站建设项目规划书案例国外一个做ppt的网站
  • 项目网站基础设施建设优秀个人博客网站
  • 建设部网站中天人建筑工程有限公司建站宝盒后台
  • 涉县做网站ps图做ppt模板下载网站有哪些
  • 怎么自己免费创建一个网站2023网页游戏排行榜
  • 还有哪些网站可以做淘宝活动吗农副产品销售网站开发
  • 江门网站微信小程序源码网
  • 制作h5网站开发网站开发总结与未来展望
  • 做谷歌网站吗湖南省建设厅建筑业信息网官网
  • 海沧建设局网站那些网站可以做问答
  • 什么做网站做个多少钱啊电影的网络营销方式
  • 四川省城乡住房和建设厅网站金科网站建设
  • 专业的网站建设托管网站企业建设
  • 个人建站做什么网站比较赚钱济南网站建设网站制作
  • 设计对网站的重要性做磨砂卡贴的网站
  • 西安 做网站win2003搭建php网站
  • 无忧网站建设哪家好在线拼图
  • 遵义在百度做个网站多少钱百度广告投放平台官网
  • 网站建设中网页代码做网站麻烦吗
  • 网站模板中企动力秦皇岛做网站外包
  • 庞各庄网站建设长沙发布致全体
  • 给单位建设网站电商网站系统建设考试