Golang精编100题3:判断题

1.【初级】数组是一个值类型()

参考答案:T

2.【初级】使用map不需要引入任何库()

参考答案:T

3.【中级】内置函数delete可以删除数组切片内的元素()

参考答案:F

4.【初级】指针是基础类型()

参考答案:F

5.【初级】 interface{}是可以指向任意对象的Any类型()

参考答案:T

6.【中级】下面关于文件操作的代码可能触发异常()

file, err := os.Open("test.go")
defer file.Close()
if err != nil {
 fmt.Println("open file failed:",err)
 return
}
...

参考答案:T

13.【初级】 Golang不支持自动垃圾回收()

参考答案:F

14.【初级】 Golang支持反射,反射最常见的使用场景是做对象的序列化()

参考答案:T

15.【初级】 Golang可以复用C/C++的模块,这个功能叫Cgo()

参考答案:F

16.【初级】下面代码中两个斜点之间的代码,比如json:“x”,作用是X字段在从结构体实例编码到JSON数据格式的时候,使用x作为名字,这可以看作是一种重命名的方式()

type Position struct {
    X int `json:"x"`
    Y int `json:"y"`
    Z int `json:"z"`
}

参考答案:T

21.【初级】通过成员变量或函数首字母的大小写来决定其作用域()

参考答案:T

22.【初级】对于常量定义zero(const zero = 0.0),zero是浮点型常量()

参考答案:F

23.【初级】对变量x的取反操作是~x()

参考答案:F

24.【初级】下面的程序的运行结果是xello()

func main() {
    str := "hello"
    str[0] = 'x'
    fmt.Println(str)
}

参考答案:F

29.【初级】 golang支持goto语句()

参考答案:T

30.【初级】下面代码中的指针p为野指针,因为返回的栈内存在函数结束时会被释放()

type TimesMatcher struct {
    base int
    }
    func NewTimesMatcher(base int) *TimesMatcher{
    return &TimesMatcher{base:base}
    }
    func main() {
    p := NewTimesMatcher(3)
    ...
}

参考答案:F

40.【初级】匿名函数可以直接赋值给一个变量或者直接执行()

参考答案:T

41.【初级】如果调用方调用了一个具有多返回值的方法,但是却不想关心其中的某个返回值,可以简单地用一个下划线“_”来跳过这个返回值,该下划线对应的变量叫匿名变量()

参考答案:T

42.【初级】在函数的多返回值中,如果有error或bool类型,则一般放在最后一个()

参考答案:T

43.【初级】错误是业务过程的一部分,而异常不是()

参考答案:T

44.【初级】函数执行时,如果由于panic导致了异常,则延迟函数不会执行()

参考答案:F

45.【中级】当程序运行时,如果遇到引用空指针、下标越界或显式调用panic函数等情况,则先触发panic函数的执行,然后调用延迟函数。调用者继续传递panic,因此该过程一直在调用栈中重复发生:函数停止执行,调用延迟执行函数。如果一路在延迟函数中没有recover函数的调用,则会到达该携程的起点,该携程结束,然后终止其他所有携程,其他携程的终止过程也是重复发生:函数停止执行,调用延迟执行函数()

参考答案:F

46.【初级】同级文件的包名不允许有多个()

参考答案:T

47.【中级】可以给任意类型添加相应的方法()

参考答案:F

48.【初级】 golang虽然没有显式的提供继承语法,但是通过匿名组合实现了继承()

参考答案:T

49.【初级】使用for range迭代map时每次迭代的顺序可能不一样,因为map的迭代是随机的()

参考答案:T

50.【初级】 switch后面可以不跟表达式()

参考答案:T

51.【中级】结构体在序列化时非导出变量(以小写字母开头的变量名)不会被encode,因此在decode时这些非导出变量的值为其类型的零值()

参考答案:T

52.【初级】 golang中没有构造函数的概念,对象的创建通常交由一个全局的创建函数来完成,以NewXXX来命名()

参考答案:T

53.【中级】当函数deferDemo返回失败时,并不能destroy已create成功的资源()

func deferDemo() error {
    err := createResource1()
    if err != nil {
       return ERR_CREATE_RESOURCE1_FAILED
    }
    
    defer func() {
       if err != nil {
           destroyResource1()
       }
    }()
     
    err = createResource2()
    if err != nil {
       return ERR_CREATE_RESOURCE2_FAILED
    }
    
    defer func() {
       if err != nil {
           destroyResource2()
       }
    }()
     
    err = createResource3()
    if err != nil {
       return ERR_CREATE_RESOURCE3_FAILED
    }
    return nil
}

参考答案:F

80.【中级】 channel本身必然是同时支持读写的,所以不存在单向channel()

参考答案:F

81.【初级】 import后面的最后一个元素是包名()

参考答案:F

你可能感兴趣的:(Go语言面试题)