Golang different package calls
Go language is an open source programming language. Its emergence has many advantages, including static type checking, garbage collection, and coroutines. When developing in the Go language, it is a common requirement to use functions and variables from different packages. This article will introduce some methods and techniques for calling different packages in the Go language.
- Import the required packages
In the Go language, we need to use the import
statement to import the required packages. For example, if we want to use the functions in the fmt
package, then we can import the fmt
package in the code:
import "fmt"
If we want to import multiple packages at the same time, You can use the following method:
import ( "fmt" "time" )
It should be noted that the imported package name must be unique. When using functions and variables in a package, you need to use the package name prefix to access them.
- Package Visibility
In the Go language, the visibility of variables, functions, constants, etc. is controlled by the case of the first letter. If the first letter of the variable we define is capitalized, then the variable can be accessed by external packages, otherwise it cannot be accessed by external packages. For example, we define the following function:
func GetUserId() string { // TODO }
Since the first letter of the function name GetUserId
is capitalized, this function can be accessed by other packages.
When we import a package, only the functions and variables exposed in the package can be accessed. For example, suppose we have a package called mylib
, which has a private variable count
:
package mylib var count int = 0
If we import mylib# in other packages ##Package cannot access the
count variable because it is a private variable.
- Package alias
fmt package as
f and later use
f.Println instead of
fmt.Println:
import f "fmt" func main() { f.Println("Hello, world!") }
- Non-local package call
go get command. For example, if you want to install the
github.com/gin-gonic/gin package, you can execute the following command:
go get github.com/gin-gonic/gin
gin in the program package to use the functions and variables in it:
import "github.com/gin-gonic/gin" func main() { router := gin.Default() router.GET("/", func(c *gin.Context) { c.String(http.StatusOK, "Hello, world!") }) router.Run(":8080") }
- Cross-package call
mylib package and a
main package, which respectively define the following functions:
// mylib包 package mylib func Add(a, b int) int { return a + b }
// main包 package main import "mylib" func main() { sum := mylib.Add(1, 2) println(sum) }
main package , use the
mylib.Add method to call the
Add function in the
mylib package.
- Interface call
type Logger interface { Log(msg string) }
Logger interface, it needs to implement the
Log method. For example, we have a structure named
FileLogger:
type FileLogger struct { file *os.File } func (l *FileLogger) Log(msg string) { l.file.WriteString(msg) }
FileLogger The structure implements
Log in the Logger
interface method, so it can be considered to implement the
Logger interface.
WriteLog, which accepts an object that implements the
Logger interface:
func WriteLog(l Logger, msg string) { l.Log(msg) }
WriteLog function:
fileLogger := &FileLogger{ file: os.Create("log.txt"), } WriteLog(fileLogger, "hello, world!")
- Type assertion
HttpResponse:
type HttpResponse interface { GetStatus() int GetBody() []byte }
JsonResponse and
TextResponse that implement this interface:
type JsonResponse struct { status int body []byte } func (r *JsonResponse) GetStatus() int { return r.status } func (r *JsonResponse) GetBody() []byte { return r.body } type TextResponse struct { status int body []byte } func (r *TextResponse) GetStatus() int { return r.status } func (r *TextResponse) GetBody() []byte { return r.body }
SendResponse, which accepts an object that implements the
HttpResponse interface.
func SendResponse(resp HttpResponse) { fmt.Printf("StatusCode: %d ", resp.GetStatus()) fmt.Printf("Body: %v ", resp.GetBody()) }
SendResponse function in the following way:
jsonResp := &JsonResponse{ status: 200, body: []byte(`{"message": "hello, world!"}`), } SendResponse(jsonResp) textResp := &TextResponse{ status: 200, body: []byte("hello, world!"), } SendResponse(textResp)
SendResponse function, we use type assertion
resp. (*JsonResponse) to determine the specific type of the
resp object. If the
resp object is of type
JsonResponse, then the value of the return value
ok is
true, and the converted
resp# will be ##The object is assigned to the json
variable; otherwise the value of the return value ok
is false
. The above are some methods and techniques for calling different packages in Go language. In actual development, making full use of these methods and techniques can improve programming efficiency and reduce the probability of code errors.
The above is the detailed content of Golang different package calls. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



OpenSSL, as an open source library widely used in secure communications, provides encryption algorithms, keys and certificate management functions. However, there are some known security vulnerabilities in its historical version, some of which are extremely harmful. This article will focus on common vulnerabilities and response measures for OpenSSL in Debian systems. DebianOpenSSL known vulnerabilities: OpenSSL has experienced several serious vulnerabilities, such as: Heart Bleeding Vulnerability (CVE-2014-0160): This vulnerability affects OpenSSL 1.0.1 to 1.0.1f and 1.0.2 to 1.0.2 beta versions. An attacker can use this vulnerability to unauthorized read sensitive information on the server, including encryption keys, etc.

The library used for floating-point number operation in Go language introduces how to ensure the accuracy is...

Queue threading problem in Go crawler Colly explores the problem of using the Colly crawler library in Go language, developers often encounter problems with threads and request queues. �...

This article introduces a variety of methods and tools to monitor PostgreSQL databases under the Debian system, helping you to fully grasp database performance monitoring. 1. Use PostgreSQL to build-in monitoring view PostgreSQL itself provides multiple views for monitoring database activities: pg_stat_activity: displays database activities in real time, including connections, queries, transactions and other information. pg_stat_replication: Monitors replication status, especially suitable for stream replication clusters. pg_stat_database: Provides database statistics, such as database size, transaction commit/rollback times and other key indicators. 2. Use log analysis tool pgBadg

Backend learning path: The exploration journey from front-end to back-end As a back-end beginner who transforms from front-end development, you already have the foundation of nodejs,...

The difference between string printing in Go language: The difference in the effect of using Println and string() functions is in Go...

The problem of using RedisStream to implement message queues in Go language is using Go language and Redis...

Under the BeegoORM framework, how to specify the database associated with the model? Many Beego projects require multiple databases to be operated simultaneously. When using Beego...
