网站首页 > 技术文章 正文
1. 【初级】下面属于关键字的是()A. funcB. defC. structD. class
参考答案:AC
2. 【初级】定义一个包内全局字符串变量,下面语法正确的是()A. var str stringB. str := ""C. str = ""D. var str = ""
参考答案:AD
3. 【初级】通过指针变量 p 访问其成员变量 name,下面语法正确的是()A. p.nameB. (*p).nameC. (&p).nameD. p->name
参考答案:AB
4. 【初级】关于接口和类的说法,下面说法正确的是()A. 一个类只需要实现了接口要求的所有函数,我们就说这个类实现了该接口B. 实现类的时候,只需要关心自己应该提供哪些方法,不用再纠结接口需要拆得多细才合理C. 类实现接口时,需要导入接口所在的包D. 接口由使用方按自身需求来定义,使用方无需关心是否有其他模块定义过类似的接口
参考答案:ABD
5. 【初级】关于字符串连接,下面语法正确的是()A. str := ‘abc’ + ‘123’B. str := "abc" + "123"C. str := '123' + "abc"D. fmt.Sprintf("abc%d", 123)
参考答案:BD
6. 【初级】关于协程,下面说法正确是()A. 协程和线程都可以实现程序的并发执行B. 线程比协程更轻量级C. 协程不存在死锁问题D. 通过channel来进行协程间的通信
参考答案:AD
7. 【中级】关于init函数,下面说法正确的是()A. 一个包中,可以包含多个init函数B. 程序编译时,先执行导入包的init函数,再执行本包内的init函数C. main包中,不能有init函数D. init函数可以被其他函数调用
参考答案:AB
8. 【初级】关于循环语句,下面说法正确的有()A. 循环语句既支持for关键字,也支持while和do-whileB. 关键字for的基本使用方法与C/C++中没有任何差异C. for循环支持continue和break来控制循环,但是它提供了一个更高级的break,可以选择中断哪一个循环D. for循环不支持以逗号为间隔的多个赋值语句,必须使用平行赋值的方式来初始化多个变量 参考答案:CD
9. 【中级】对于函数定义:
func add(args ...int) int { sum :=0 for _,arg := range args { sum += arg } return sum}
下面对add函数调用正确的是()A. add(1, 2)B. add(1, 3, 7)C. add([]int{1, 2})D. add([]int{1, 3, 7}...)
参考答案:ABD
16. 【初级】关于类型转化,下面语法正确的是()A.
type MyInt intvar i int = 1var jMyInt = i
B.
type MyIntintvar i int= 1var jMyInt = (MyInt)i
C.
type MyIntintvar i int= 1var jMyInt = MyInt(i)
D.
type MyIntintvar i int= 1var jMyInt = i.(MyInt)
参考答案:C
19. 【初级】关于局部变量的初始化,下面正确的使用方式是()A. var i int = 10B. var i = 10C. i := 10D. i = 10
参考答案:ABC
20. 【初级】关于const常量定义,下面正确的使用方式是()A.
const Pi float64 = 3.14159265358979323846const zero= 0.0
B.
const ( size int64= 1024 eof = -1)
C.
const ( ERR_ELEM_EXISTerror = errors.New("element already exists") ERR_ELEM_NT_EXISTerror = errors.New("element not exists"))
D.
const u, vfloat32 = 0, 3const a,b, c = 3, 4, "foo"
参考答案:ABD
22. 【初级】关于布尔变量b的赋值,下面错误的用法是()A. b = trueB. b = 1C. b = bool(1)D. b = (1 == 2)
参考答案:BC
23. 【中级】下面的程序的运行结果是()
func main() { if (true) { defer fmt.Printf("1") } else { defer fmt.Printf("2") } fmt.Printf("3")}
A. 321B. 32C. 31D. 13
参考答案:C
31. 【初级】关于switch语句,下面说法正确的有()A. 条件表达式必须为常量或者整数B. 单个case中,可以出现多个结果选项C. 需要用break来明确退出一个caseD. 只有在case中明确添加fallthrough关键字,才会继续执行紧跟的下一个case
参考答案:BD
32. 【中级】 golang中没有隐藏的this指针,这句话的含义是()A. 方法施加的对象显式传递,没有被隐藏起来B. golang沿袭了传统面向对象编程中的诸多概念,比如继承、虚函数和构造函数C. golang的面向对象表达更直观,对于面向过程只是换了一种语法形式来表达D. 方法施加的对象不需要非得是指针,也不用非得叫this
参考答案:ACD
33. 【中级】 golang中的引用类型包括()A. 数组切片B. mapC. channelD. interface
参考答案:ABCD
34. 【中级】 golang中的指针运算包括()A. 可以对指针进行自增或自减运算B. 可以通过“&”取指针的地址C. 可以通过“*”取指针指向的数据D. 可以对指针进行下标运算
参考答案:BC
35. 【初级】关于main函数(可执行程序的执行起点),下面说法正确的是()A. main函数不能带参数B. main函数不能定义返回值C. main函数所在的包必须为main包D. main函数中可以使用flag包来获取和解析命令行参数
参考答案:ABCD
36. 【中级】下面赋值正确的是()A. var x = nilB. var x interface{} = nilC. var x string = nilD. var x error = nil
参考答案:BD
37. 【中级】关于整型切片的初始化,下面正确的是()A. s := make([]int)B. s := make([]int, 0)C. s := make([]int, 5, 10)D. s := []int{1, 2, 3, 4, 5}
参考答案:BCD
38. 【中级】从切片中删除一个元素,下面的算法实现正确的是()A.
func (s *Slice)Remove(value interface{})error { for i, v := range *s { if isEqual(value, v) { if i== len(*s) - 1 { *s = (*s)[:i] }else { *s = append((*s)[:i],(*s)[i + 2:]...) } return nil }} return ERR_ELEM_NT_EXIST }
B.
func (s*Slice)Remove(value interface{}) error { for i, v:= range *s { if isEqual(value, v) { *s =append((*s)[:i],(*s)[i + 1:]) return nil } } return ERR_ELEM_NT_EXIST }
C.
func (s*Slice)Remove(value interface{}) error {for i, v:= range *s { if isEqual(value, v) { delete(*s, v) return nil }} return ERR_ELEM_NT_EXIST}
D.
func (s*Slice)Remove(value interface{}) error { for i, v:= range *s { if isEqual(value, v) { *s =append((*s)[:i],(*s)[i + 1:]...) return nil } } return ERR_ELEM_NT_EXIST}
参考答案:D
51. 【初级】对于局部变量整型切片x的赋值,下面定义正确的是()A.
x := []int{ 1, 2, 3, 4, 5, 6,}
B.
x :=[]int{ 1, 2, 3, 4, 5, 6}
C.
x :=[]int{ 1, 2, 3, 4, 5, 6}
D.
x :=[]int{1, 2, 3, 4, 5, 6,}
参考答案:ACD
55. 【初级】关于变量的自增和自减操作,下面语句正确的是()A.
i := 1i++
B.
i := 1j = i++
C.
i := 1++i
D.
i := 1i--
参考答案:AD
57. 【中级】关于函数声明,下面语法错误的是()A. func f(a, b int) (value int, err error)B. func f(a int, b int) (value int, err error)C. func f(a, b int) (value int, error)D. func f(a int, b int) (int, int, error)
参考答案:C
58. 【中级】如果Add函数的调用代码为:
func main() { var a Integer = 1 var b Integer = 2 var i interface{} = &a sum := i.(*Integer).Add(b) fmt.Println(sum)}
则Add函数定义正确的是()A.
type Integer intfunc (a Integer) Add(b Integer) Integer { return a + b}
B.
type Integer intfunc (a Integer) Add(b *Integer) Integer { return a + *b}
C.
type Integer intfunc (a* Integer) Add(b Integer) Integer { return *a + b}
D.
type Integer intfunc (a* Integer) Add(b *Integer) Integer { return *a + *b}
参考答案:AC
65. 【中级】如果Add函数的调用代码为:
func main() { var a Integer = 1 var b Integer = 2 var i interface{} = a sum := i.(Integer).Add(b) fmt.Println(sum)}
则Add函数定义正确的是()A.
type Integer intfunc (a Integer)Add(b Integer) Integer { return a + b}
B.
type Integer intfunc (aInteger) Add(b *Integer) Integer { return a + *b}
C.
type Integer intfunc (a*Integer) Add(b Integer) Integer { return *a + b}
D.
type Integer intfunc (a*Integer) Add(b *Integer) Integer { return *a + *b}
参考答案:A
72. 【中级】关于GetPodAction定义,下面赋值正确的是()
type Fragment interface { Exec(transInfo *TransInfo) error} type GetPodAction struct {} func (g GetPodAction) Exec(transInfo*TransInfo) error { ... return nil}
A. var fragment Fragment =new(GetPodAction)B. var fragment Fragment = GetPodActionC. var fragment Fragment = &GetPodAction{}D. var fragment Fragment = GetPodAction{}
参考答案:ACD
81. 【中级】关于GoMock,下面说法正确的是()A. GoMock可以对interface打桩B. GoMock可以对类的成员函数打桩C. GoMock可以对函数打桩D. GoMock打桩后的依赖注入可以通过GoStub完成
参考答案:AD
82. 【中级】关于接口,下面说法正确的是()A. 只要两个接口拥有相同的方法列表(次序不同不要紧),那么它们就是等价的,可以相互赋值B. 如果接口A的方法列表是接口B的方法列表的子集,那么接口B可以赋值给接口AC. 接口查询是否成功,要在运行期才能够确定D. 接口赋值是否可行,要在运行期才能够确定
参考答案:ABC
83. 【初级】关于channel,下面语法正确的是()A. var ch chan intB. ch := make(chan int)C. <- chD. ch <-
参考答案:ABC
84. 【初级】关于同步锁,下面说法正确的是()A. 当一个goroutine获得了Mutex后,其他goroutine就只能乖乖的等待,除非该goroutine释放这个MutexB. RWMutex在读锁占用的情况下,会阻止写,但不阻止读C. RWMutex在写锁占用情况下,会阻止任何其他goroutine(无论读和写)进来,整个锁相当于由该goroutine独占D. Lock()操作需要保证有Unlock()或RUnlock()调用与之对应
参考答案:ABC
85. 【中级】 golang中大多数数据类型都可以转化为有效的JSON文本,下面几种类型除外()A. 指针B. channelC. complexD. 函数
参考答案:BCD
86. 【中级】关于go vendor,下面说法正确的是()A. 基本思路是将引用的外部包的源代码放在当前工程的vendor目录下面B. 编译go代码会优先从vendor目录先寻找依赖包C. 可以指定引用某个特定版本的外部包D. 有了vendor目录后,打包当前的工程代码到其他机器的$GOPATH/src下都可以通过编译
参考答案:ABD
87. 【初级】 flag是bool型变量,下面if表达式符合编码规范的是()A. if flag == 1B. if flagC. if flag == falseD. if !flag
参考答案:BD
88. 【初级】 value是整型变量,下面if表达式符合编码规范的是()A. if value == 0B. if valueC. if value != 0D. if !value
参考答案:AC
89. 【中级】关于函数返回值的错误设计,下面说法正确的是()A. 如果失败原因只有一个,则返回boolB. 如果失败原因超过一个,则返回errorC. 如果没有失败原因,则不返回bool或errorD. 如果重试几次可以避免失败,则不要立即返回bool或error
参考答案:ABCD
90. 【中级】关于异常设计,下面说法正确的是()A. 在程序开发阶段,坚持速错,让程序异常崩溃B. 在程序部署后,应恢复异常避免程序终止C. 一切皆错误,不用进行异常设计D. 对于不应该出现的分支,使用异常处理
参考答案:ABD
91. 【中级】关于slice或map操作,下面正确的是()A.
var s []ints =append(s,1)
B.
var mmap[string]intm["one"]= 1
C.
var s[]ints =make([]int, 0)s =append(s,1)
D.
var mmap[string]intm =make(map[string]int)m["one"]= 1
参考答案:ACD
93. 【中级】关于channel的特性,下面说法正确的是()A. 给一个 nil channel 发送数据,造成永远阻塞B. 从一个 nil channel 接收数据,造成永远阻塞C. 给一个已经关闭的 channel 发送数据,引起 panicD. 从一个已经关闭的 channel 接收数据,如果缓冲区中为空,则返回一个零值
参考答案:ABCD
94. 【中级】关于无缓冲和有冲突的channel,下面说法正确的是()A. 无缓冲的channel是默认的缓冲为1的channelB. 无缓冲的channel和有缓冲的channel都是同步的C. 无缓冲的channel和有缓冲的channel都是非同步的D. 无缓冲的channel是同步的,而有缓冲的channel是非同步的
参考答案:D
95. 【中级】关于异常的触发,下面说法正确的是()A. 空指针解析B. 下标越界C. 除数为0D. 调用panic函数
参考答案:ABCD
96. 【中级】关于cap函数的适用类型,下面说法正确的是()A. arrayB. sliceC. mapD. channel
参考答案:ABD
97. 【中级】关于beego框架,下面说法正确的是()A. beego是一个golang实现的轻量级HTTP框架B. beego可以通过注释路由、正则路由等多种方式完成url路由注入C. 可以使用bee new工具生成空工程,然后使用bee run命令自动热编译D. beego框架只提供了对url路由的处理,而对于MVC架构中的数据库部分未提供框架支持
参考答案:ABC
98. 【中级】关于goconvey,下面说法正确的是()A. goconvey是一个支持golang的单元测试框架B. goconvey能够自动监控文件修改并启动测试,并可以将测试结果实时输出到web界面C. goconvey提供了丰富的断言简化测试用例的编写D. goconvey无法与go test集成
参考答案:ABC
99. 【中级】关于go vet,下面说法正确的是()A. go vet是golang自带工具go tool vet的封装B. 当执行go vet database时,可以对database所在目录下的所有子文件夹进行递归检测C. go vet可以使用绝对路径、相对路径或相对GOPATH的路径指定待检测的包D. go vet可以检测出死代码
参考答案:ACD
100.【中级】关于map,下面说法正确的是()A. map反序列化时json.unmarshal的入参必须为map的地址B. 在函数调用中传递map,则子函数中对map元素的增加不会导致父函数中map的修改C. 在函数调用中传递map,则子函数中对map元素的修改不会导致父函数中map的修改D. 不能使用内置函数delete删除map的元素
参考答案:A
101.【中级】关于GoStub,下面说法正确的是()A. GoStub可以对全局变量打桩B. GoStub可以对函数打桩C. GoStub可以对类的成员方法打桩D. GoStub可以打动态桩,比如对一个函数打桩后,多次调用该函数会有不同的行为
参考答案:ABD
102.【初级】关于select机制,下面说法正确的是()A. select机制用来处理异步IO问题B. select机制最大的一条限制就是每个case语句里必须是一个IO操作C. golang在语言级别支持select关键字D. select关键字的用法与switch语句非常类似,后面要带判断条件
参考答案:ABC
103.【初级】关于内存泄露,下面说法正确的是()A. golang有自动垃圾回收,不存在内存泄露B. golang中检测内存泄露主要依靠的是pprof包C. 内存泄露可以在编译阶段发现D. 应定期使用浏览器来查看系统的实时内存信息,及时发现内存泄露问题
参考答案:BD
填空题
1. 【初级】声明一个整型变量i__________
参考答案:var i int
2. 【初级】声明一个含有10个元素的整型数组a__________
参考答案:var a [10]int
3. 【初级】声明一个整型数组切片 s __________
参考答案:var s []int
4. 【初级】声明一个整型指针变量 p __________
参考答案:var p *int
5. 【初级】声明一个key为字符串型value为整型的map变量m__________
参考答案:var m map[string]int
6. 【初级】声明一个入参和返回值均为整型的函数变量f__________
参考答案:var f func(a int) int
7. 【初级】声明一个只用于读取int数据的单向channel变量ch__________
参考答案:var ch <-chan int
8. 【初级】假设源文件的命名为slice.go,则测试文件的命名为__________
参考答案:slice_test.go
9. 【初级】 go test要求测试函数的前缀必须命名为__________
参考答案:Test
10. 【中级】下面的程序的运行结果是__________
for i := 0; i < 5; i++ { defer fmt.Printf("%d ", i)}
参考答案:4 3 2 1 0
13. 【中级】下面的程序的运行结果是__________
func main() { x := 1 { x := 2 fmt.Print(x) } fmt.Println(x)}
参考答案:21
21. 【中级】下面的程序的运行结果是__________
func main() { strs := []string{"one","two", "three"} for _, s := range strs { go func() { time.Sleep(1 * time.Second) fmt.Printf("%s ", s) }() } time.Sleep(3 * time.Second)}
参考答案:three threethree
32. 【中级】下面的程序的运行结果是__________
func main() { x := []string{"a", "b","c"} for v := range x { fmt.Print(v) }}
参考答案:012
38. 【中级】下面的程序的运行结果是__________
func main() { x := []string{"a", "b","c"} for _, v := range x { fmt.Print(v) }}
参考答案:abc
44. 【初级】下面的程序的运行结果是__________
func main() { i := 1 j := 2 i, j = j, i fmt.Printf("%d%d\n", i, j)}
参考答案:21
50. 【初级】下面的程序的运行结果是__________
func incr(p *int) int { *p++ return *p}func main() { v := 1 incr(&v) fmt.Println(v)}
参考答案:2
59. 【初级】启动一个goroutine的关键字是__________
参考答案:go
60. 【中级】下面的程序的运行结果是__________
type Slice []intfunc NewSlice() Slice { return make(Slice, 0)}func (s* Slice) Add(elem int) *Slice { *s = append(*s, elem) fmt.Print(elem) return s}func main() { s := NewSlice() defer s.Add(1).Add(2) s.Add(3)}
参考答案:132
参考:go语言中文文档:www.topgoer.com
转自:https://blog.csdn.net/caoshiminYQS/article/details/100415466
猜你喜欢
- 2024-11-02 武汉课工场大数据培训:Java正则表达式入坑指南
- 2024-11-02 Go语言进阶之路:并发爬虫,爬取空姐网所有相册图片
- 2024-11-02 golang常用库:gorilla/mux-http路由库使用
- 2024-11-02 golang 使用pprof和go-torch做性能分析
- 2024-11-02 Golang Gin 入门 (一)(golang官方教程)
- 2024-11-02 日志文件转运工具Filebeat笔记(日志转载)
- 2024-11-02 Linux 命令行下搜索工具大盘点,效率提高不止一倍
- 2024-11-02 SlimTrie:战胜Btree单机百亿文件的极致索引-实现篇
- 2024-11-02 Go的安全编程和防御性编程(输入验证和过滤)
- 2024-11-02 清华学神尹成带你学习golang2021(56)(Go语言测试命令)
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)