欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

go golang 笔试题 面试题 笔试 面试

程序员文章站 2022-06-04 11:10:23
发现go的笔试题目和面试题目还都是比较少的,于是乎就打算最近总结一下。虽然都不难,但是如果没有准备猛地遇到了还是挺容易踩坑的。 就是几个简单的笔试题目,也可能面试的时候直接给看让说结果。go面试题大本营 问题在于,ages没有暴露背外部的包,导致调用者无法初始化ages。然后在调用add函数时,就会 ......

发现go的笔试题目和面试题目还都是比较少的,于是乎就打算最近总结一下。虽然都不难,但是如果没有准备猛地遇到了还是挺容易踩坑的。

就是几个简单的笔试题目,也可能面试的时候直接给看让说结果。

1, 用不同的goroutine去操作map的时候会存在线程同步的问题,把map换成int ,这个问题同样存在。在go里是这样。
2,下面这段代码输出的值为:
    func (){
    jsonstr:=[]byte(`{"age":1}`)
    var value map[string]interface{}
    json.unmarshal(jsonstr,&value)
    age:=value["age"]
    fmt.println(reflect.typeof(age))
    //float64
}
3,下边代码是否有问题,问题在哪里
    import (
    "sync"
    "fmt"
)
type userages struct {
    ages map[string] int
    sync.mutex
}

func (u *userages)add(name string,age int)  {
    u.lock()
    defer u.unlock()
    u.ages[name] = age
}

func (u *userages)get(name string)int{
    if age,ok:=u.ages[name];ok{
        return age
    }
    return -1
}

问题在于,ages没有暴露背外部的包,导致调用者无法初始化ages。然后在调用add函数时,就会报错。考察函数的作用域问题。

4,下边代码的输出结果是什么?
func testarrayandslice(){
    s1:=[]int{1,2,3}
    s2:=s1[1:]
    for i:=range s2{
        s2[i]+=10
    }
    fmt.println(s2)
    s2=append(s2, 4)
    for i:=range s2{
        s2[i]+=10
    }
    fmt.println(s2)
}

输出结果如下:这个是在考察数组和切片用s2截取s1的下边为1及之后;而后执行操作。

[12 13]
[22 23 14]

5,下边代码输出什么
func testdoit(){
   doit:= func(arg int) interface{}{
       var result *struct{}=nil

       if (arg>0) {
           result = &struct{}{}
       }
       return result
   }
   //输出结果。
   //-1:result: <nil>    为空的匿名结构体
   //1://result: &{}     匿名结构体的地址
   if res:=doit(1);res!=nil{
       fmt.println("result:",res)
   }

}
6,下边代码的输出结果是什么
//放在main里边
    //指定只能用一个逻辑处理器,方便看调度顺序。
    runtime.gomaxprocs(1)
    wg:=sync.waitgroup{}
    wg.add(20)
    for i:=0;i<10 ;i++  {
        go func() {
            fmt.println("i",i)
            wg.done()
        }()
    }
    for i:=0;i<10 ;i++  {
        go func(i int) {
            fmt.println("j",i)
            wg.done()
        }(i)
    }
    wg.wait()

    /*
    j 9
    i 10
    i 10
    i 10
    i 10
    i 10
    i 10
    i 10
    i 10
    i 10
    i 10
    j 0
    j 1
    j 2
    j 3
    j 4
    j 5
    j 6
    j 7
    j 8
     */

这个要注意,第一个for里没有传参数,第二个传参数了。所以第一个for里启动的goroutine用的i其实是主线程里的i;之所以都是10,(也有可能前面几个<10);是因为调用i的时候,i在主线程内已经加到10了。而第二个for里的i是通过参数传递,所以会打印0~9;
至于为什么会先打印j,9;希望有大神来回答下。

暂时先写这么多,回头再接着加。

转载注明出处--名白

http://www.cnblogs.com/mingbai/p/go-golangcodingtest.html