Go 언어에서는 time 패키지의 Since() 함수를 사용하여 함수 실행 시간을 얻을 수 있습니다. 함수가 실행되기 전의 시작 시간을 설정하고, 시작 시간부터 함수 실행이 끝나는 현재까지의 시간 간격을 구합니다. 이 시간 간격은 함수 실행 시간이며 다음을 사용하여 계산할 수 있습니다. time.Since() 함수, "time.Since(t)" 구문은 t에서 지금까지 경과된 시간을 반환합니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.
시간을 사용하세요. 실행 시간을 계산하기 때문에
함수의 실행 시간의 길이는 이 함수의 성능을 측정하는 중요한 지표이며, 특히 비교 및 벤치마크 테스트에서 실행을 얻는 가장 쉬운 방법입니다. 함수 실행 시간 함수가 실행되기 전의 시작 시간을 설정하는 것으로, 시작 시간부터 함수 실행이 끝난 현재까지의 시간 간격을 구하는 것이 이 시간 간격이 함수의 실행 시간이다.
Go 언어에서는 time 패키지의 Since() 함수를 사용하여 함수의 실행 시간을 얻을 수 있습니다. 공식 Go 언어 문서에 있는 Since() 함수에 대한 소개는 다음과 같습니다.
func Since(t Time) Duration
Since() 함수는 t에서 지금까지 경과된 시간을 반환하며 이는 time.Now().Sub(t)와 동일합니다.
예제 1: Since() 함수를 사용하여 함수의 실행 시간을 가져옵니다.
package main import ( "fmt" "time" ) func test() { start := time.Now() // 获取当前时间 sum := 0 for i := 0; i < 100000000; i++ { sum++ } elapsed := time.Since(start) fmt.Println("该函数执行完成耗时:", elapsed) } func main() { test() }
실행 결과는 다음과 같습니다.
该函数执行完成耗时: 39.8933ms
위에서 time.Now().Sub() 함수가 있다고 언급했습니다. 이는 Since() 함수와 유사합니다. time.Now().Sub()를 사용하여 함수의 실행 시간을 얻으려면 위 코드의 14행만 수정하면 됩니다.
예 2: time.Now().Sub()를 사용하여 함수의 실행 시간을 가져옵니다.
package main import ( "fmt" "time" ) func test() { start := time.Now() // 获取当前时间 sum := 0 for i := 0; i < 100000000; i++ { sum++ } elapsed := time.Now().Sub(start) fmt.Println("该函数执行完成耗时:", elapsed) } func main() { test() }
실행 결과는 다음과 같습니다.
该函数执行完成耗时: 36.8769ms
컴퓨터 CPU 및 기타 요인의 영향으로 인해 , 함수의 실행 시간을 가져올 때 결과는 매번 약간씩 달라지며 이는 정상적인 현상입니다.
지식 확장: time.Now().Sub()를 사용하여 시차를 계산합니다.
다음과 같이 time.Since()를 time.Now().Sub()로 바꾸면 됩니다.
start := time.Now() // 获取当前时间 sum := 0 for i := 0; i < 100000000; i++ { sum++ } elapsed := time.Now().Sub(start) fmt.Println(elapsed)
실제로 time.Since는 내부적으로 Sub 함수를 호출하므로 time 패키지에 들어가 보겠습니다. 주석은 Since가 t 이후 경과된 시간을 반환한다는 의미입니다. .Sub(t),
srctimetime.go 923:6
// Since returns the time elapsed since t. // It is shorthand for time.Now().Sub(t). func Since(t Time) Duration { var now Time if t.wall&hasMonotonic != 0 { // Common case optimization: if t has monotonic time, then Sub will use only it. now = Time{hasMonotonic, runtimeNano() - startNano, nil} } else { now = Now() } return now.Sub(t) }
time.Now().Sub(start).Seconds()를 사용하여 경과된 초 수를 얻을 수도 있습니다. 경과한 시간 등을 얻으려면 해당 시간을 time.Since(start).Seconds(), time.Since(start).Seconds() 등으로 축약할 수도 있습니다.
【관련 추천: Go 비디오 튜토리얼, 프로그래밍 교육】
위 내용은 Go 언어에서 함수 실행 시간을 얻는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

本篇文章带大家了解一下golang 的几种常用的基本数据类型,如整型,浮点型,字符,字符串,布尔型等,并介绍了一些常用的类型转换操作。

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

在写 Go 的过程中经常对比这两种语言的特性,踩了不少坑,也发现了不少有意思的地方,下面本篇就来聊聊 Go 自带的 HttpClient 的超时机制,希望对大家有所帮助。

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.
