23.1 时间-获取时间、休眠、超时

1. 获取时间

时间是个重要的编程元素,可用于计算间隔、同步服务器以及控制超时。

计算机中的时间分为以下两种形式:

  • 墙钟时间:以12或24小时为周期不断重复,不同的地区和季节会因时区或夏令时而异。
  • 单调时间:从一个时间原点,如进程启动时刻,持续计时,不受系统时间设置的影响。

Go语言标准库提供了time包,其中包含获取时间和测量时间的函数及方法。

time包的Now函数返回该函数被调用时的系统时间。

  • fmt.Println(time.Now())
  • 2020-02-09 21:25:05.6060644 +0800 CST m=+0.014057501
    • 当前日期:2020年02月09日
    • 当前时间:21时25分5.6060644秒
    • 所在时区:东(+)八区(0800)中国标准时间(China Standard Time, CST)
    • 单调时间:自进程启动以来0.014057501秒
// 打印当前时间
// time包的Now函数返回当前时间
package main

import (
    "fmt"
    "time"
)

func main() {
    fmt.Println(time.Now())
}
// 打印输出:
2020-02-09 21:25:05.6060644 +0800 CST m=+0.014057501 

 2. 休眠

在计算机程序中,休眠意味着让程序暂停运行。

time包的Sleep函数可令当前线程处于休眠状态,即什么都不做。

  • time.Sleep(3 * time.Second)
    • 执行该函数的Goroutine休眠3秒钟,其它部分不受影响,继续运行。

一个线程可以通过休眠来等待其它线程中特定任务的完成。

  • 通过时间对线程之间的同步实现简单的控制。

        借助通道建立起来的"停——等"机制效果会更好(详情请查看前文channel的内容)。

// 休眠
// 休眠意味着暂停当前“线程”的运行
package main
import (
    "fmt"
    "time"
)

func main() {
    a, b := 19, 23

    fmt.Printf("You have 10 seconds to calculate %vx%v ...\n", a, b)
    fmt.Printf("[%*v", 41, "]")

    for seconds := 0; seconds < 10; seconds++ {
	time.Sleep(time.Second)
        fmt.Printf("\r[")
        for i := 0; i < seconds+1; i++ {
            fmt.Printf("■■■■")
        }
        fmt.Printf("%*v", 4*(9-seconds)+1, "]")
    }

    fmt.Printf("\nTime's up! The answer is %v. Did you get it?\n", a*b)
}
// 打印输出:
You have 10 seconds to calculate 19x23 ...
 [■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■]
 Time's up! The answer is 437. Did you get it? 

 3.超时

time包的After函数会开启一个子线程,同时向父线程返回一个超时通道(channel)。

  • 子线程在等待参数给定的时间后,向超时通道发送一个Time类型的数据
    • 父线程通过select语句监视包括超时通道在内的多个通道,当超时通道可读时结束阻塞

基于select语句的超时控制。

  • select {
    case message := <-c: // 有消息处理消息
            fmt.Println("Received message:", message)
    case <-time.After(3 * time.Second): // 没消息最多等3秒钟
            fmt.Println("Time's up!")
    }
// 超时(其他实例参见“通道”章节)
// time包的After函数返回一个通道,该通道在指定时间间隔后被写入时间消息
package main
import (
    "fmt"
    "time"
)

func main() {
    a, b := 19, 23

    fmt.Printf("You have 10 seconds to calculate %vx%v ...\n", a, b)
    fmt.Printf("[%*v", 41, "]")

    for seconds := 0; seconds < 10; seconds++ {
	select {
        case <-time.After(time.Second):
            fmt.Printf("\r[")
            for i := 0; i < seconds+1; i++ {
                fmt.Printf("■■■■")
            }
            fmt.Printf("%*v", 4*(9-seconds)+1, "]")
        }
    }

    fmt.Printf("\nTime's up! The answer is %v. Did you get it?\n", a*b)
}
// 打印输出:
You have 10 seconds to calculate 19x23 ...
 [■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■]
 Time's up! The answer is 437. Did you get it? 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/714221.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

诊断解决方案——CANdesc和MICROSAR

文章目录 一、CANdesc二、MICROSAR一、CANdesc canbeded是Vector汽车电子开发软件Nun Autosar标准的工具链之一。 canbeded是以源代码的形式提供的可重用的组件,包括CAN Driver,交互层(IL),网络管理(NM),传输层(TP),诊断层(CANdesc) , 通信测量和标定协议(CCP,XCP) 和 通信控…

Es 索引查询排序分析

文章目录 概要一、Es数据存储1.1、_source1.2、stored fields 二、Doc values2.1、FieldCache2.2、DocValues 三、Fielddata四、Index sorting五、小结六、参考 概要 倒排索引 优势在于快速的查找到包含特定关键词的所有文档&#xff0c;但是排序&#xff0c;过滤、聚合等操作…

并发容器(二):Concurrent类下的ConcurrentHashMap源码级解析

并发容器-ConcurrentHashMap 前言数据结构JDK1.7版本HashEntrySegment 初始化 重要方法Put方法扩容rehash方法 前言 之前我们在集合篇里聊完了HashMap和HashTable&#xff0c;我们又学习了并发编程的基本内容&#xff0c;现在我们来聊一聊Concurrent类下的重要容器&#xff0c…

tsp可视化python

随机生成点的坐标并依据点集生成距离矩阵&#xff0c;通过点的坐标实现可视化 c代码看我的这篇文章tsp动态规划递归解法c from typing import List, Tuple import matplotlib.pyplot as plt from random import randintN: int 4 MAX: int 0x7f7f7f7fdistances: List[List[in…

最长不下降子序列LIS详解

最长不下降子序列指的是在一个数字序列中&#xff0c;找到一个最长的子序列&#xff08;可以不连续&#xff09;&#xff0c;使得这个子序列是不下降&#xff08;非递减&#xff09;的。 假如&#xff0c;现有序列A[1&#xff0c;2&#xff0c;3&#xff0c;-1&#xff0c;-2&…

60.WEB渗透测试-信息收集- 端口、目录扫描、源码泄露(8)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;59.WEB渗透测试-信息收集- 端口、目录扫描、源码泄露&#xff08;7&#xff09; 御剑是用…

植物大战僵尸杂交版全新版v2.1解决全屏问题

文章目录 &#x1f68b;一、植物大战僵尸杂交版❤️1. 游戏介绍&#x1f4a5;2. 如何下载《植物大战僵尸杂交版》 &#x1f680;二、解决最新2.1版的全屏问题&#x1f308;三、画质增强以及减少闪退 &#x1f68b;一、植物大战僵尸杂交版 《植物大战僵尸杂交版》是一款在原版《…

【Android】三种常见的布局LinearLayout、GridLayout、RelativeLayout

【Android】三种常见的布局LinearLayout、GridLayout、RelativeLayout 在 Android 开发中&#xff0c;布局&#xff08;Layout&#xff09;是构建用户界面的基础。通过合理的布局管理&#xff0c;可以确保应用在不同设备和屏幕尺寸上都能有良好的用户体验。本文将简单介绍 And…

困惑度作为nlp指标的理解示例

为了更清晰地说明困惑度的计算过程以及如何通过困惑度判断模型的优劣&#xff0c;我们可以通过一个简单的例子来演示。假设我们有一个非常简单的文本语料库和两个基础的语言模型进行比较。 示例文本 假设我们的文本数据包括以下两个句子&#xff1a; “cat sits on the mat”…

蔡崇信“预言”:微软与OpenAI未来极有可能会分道扬镳

近日&#xff0c;在美国投行摩根大通于上海举行的第二十届全球中国峰会上&#xff0c;阿里巴巴集团联合创始人、董事局主席蔡崇信与摩根大通北亚区董事长兼大中华区投资银行业务副主席关金星&#xff08;Kam Shing Kwang&#xff09;进行了一场精彩对话。蔡崇信深入分享了他对公…

线上教育培训办公系统系统的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;管理员管理&#xff0c;教师管理&#xff0c;学生管理&#xff0c;运营事件管理 教师账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;学生管理&#xff0c;作业管理&#xff0c;电…

OpenCore 引导完美升级

备份原有 OC (做好回滚的准备下载新版 OpenCore https://github.com/acidanthera/OpenCorePkg/releases将 1, 3, 4 里面的文件使用新版进行替换 4 里面的文件严格来说并不需要, 只是留着方便使用不追求完美到这就可以收工了将 OC 复制到 U 盘 EFI U 盘格式化可以使用: diskutil…

js 用正则表达式 匹配自定义字符之间的字符串数据,如:( )、[ ]、{ }、< >、【】等括号之间的字符串数据

要使用正则表达式匹配尖括号()之间的数据&#xff0c;可以使用以下代码示例&#xff1a; 在JavaScript中&#xff0c;你可以使用正则表达式来匹配括号()之间的数据。以下是一个简单的例子&#xff0c;它展示了如何使用正则表达式来获取两对括号之间的文本。 // 示例字符串 con…

Spring-kafka消费者消费的一些问题

前言 Spring Kafka 无缝集成了 Spring Boot、Spring Framework 及其生态系统中的其他项目&#xff0c;如 Spring Cloud。通过与 Spring Boot 的自动配置结合&#xff0c;开发者可以快速启动和配置 Kafka 相关的功能。无需编写大量样板代码即可实现 Kafka 的生产和消费功能&…

现在用U盘的人还多吗?多用于哪些场景?

在公司中使用U盘的人仍然相当多&#xff0c;主要在以下场景下使用&#xff1a; 数据存储与备份&#xff1a;U盘作为一种便携式存储设备&#xff0c;被广泛应用于数据的存储和备份。对于需要经常在不同设备或地点之间传输数据的员工来说&#xff0c;U盘提供了一个方便、快捷的解…

如何使用ios自带语音转文字工具?

ios自带语音转文字是iOS系统中自带的语音转文字功能主要应用于以下几个方面&#xff1a; 1. 语音输入&#xff1a;在iOS的任何文本输入框中&#xff0c;通常都有一个麦克风图标&#xff0c;点击后可以进行语音输入&#xff0c;系统会将你的语音实时转换成文字。 2. Siri&…

ESD与EOS区别

最近小白在做项目时&#xff0c;被一个实习生问道了&#xff0c;关于EOS与ESD区别。说实话&#xff0c;以前专注于测试debug的我&#xff0c;在回答对方时&#xff0c;并没法做到太全面的解答。于是乎&#xff0c;借助周内的空闲时间&#xff0c;小白还是简单学习总结了一番。 …

OceanBase 金融项目优化案例

领导让我帮忙支持下其他项目的SQL优化工作&#xff0c;呦西&#xff0c;是收集案例的好机会。&#x1f60d; 下面SQL都是在不能远程的情况下&#xff0c;按照原SQL的逻辑等价改写完成发给现场同学验证。 案例一 慢SQL&#xff0c;4.32秒&#xff1a; SELECT MY_.*, RM FROM (SE…

【MATLAB】(高数)

参考文章 函数极限 导数与偏导 极值和最值 局部范围的最值 局部范围内的最值&#xff0c;相当于函数的极值 离散数据的最值 多元函数的极值 fminunc [x, fval] fminunc(fun, x0)fun为代求极值的函数&#xff1b;x0为起始点&#xff0c;即从这个点开始寻找极值&#xff0c;…

Ui学习--UITableView

UI学习 UITableView基础UITableView协议UITableView高级协议与单元格总结 UITableView基础 UITableView作为iOS中的一个控件&#xff0c;用于以表格形式展示数据。例如通讯录好友&#xff0c;朋友圈信息等&#xff0c;都是UITableView的实际运用场景。 首先我们先要加入两个协…