百度国际化— 社招Go(过) — 一面技术-深圳 - 7.8

一面-1小时 2024-7-8

  1. 自我介绍
  2. 共享屏幕
  3. 算法
    1. 两数之和
      1. 用暴力枚举写一了一下,问如何优化。
func twoSum(nums []int, target int) []int {
    for i, x := range nums {
        for j := i + 1; j < len(nums); j++ {
            if x+nums[j] == target {
                return []int{i, j}
            }
        }
    }
    return nil
}
  2. 用哈希表写了一下。 
func twoSum(nums []int, target int) []int {
    hashTable := map[int]int{}
    for i, x := range nums {
        if p, ok := hashTable[target-x]; ok {
            return []int{p, i}
        }
        hashTable[x] = i
    }
    return nil
}
     1. hashTable里面存的是什么?

2. 假如给 10 个 url,通过并发实现哪些 url 能通,最后一次性输出通的url和不通的url。go 实现 1. 先写的输出的通的,然后让输出不通的,都要一次性输出。 2. 让优化代码风格,注意变量命名 3. checkUrl函数优化,resp.Body.Close() 4. 以下是我的代码

package main

import (
	"fmt"
	"net/http"
	"sync"
)

// checkUrl
func checkUrl(url string, wg *sync.WaitGroup, reachableChan, unreachableChan chan<- string) {
	defer wg.Done()
	resp, err := http.Get(url)
	if err != nil || resp.StatusCode != http.StatusOK {
		unreachableChan <- url
		return
	}
	resp.Body.Close()
	reachableChan <- url
}

// checkUrl2  优化后的
func checkUrl2(url string, wg *sync.WaitGroup, reachableChan, unreachableChan chan<- string) {
	defer wg.Done()
	resp, err := http.Get(url)
	if err != nil {
		fmt.Printf("Error fetching URL %s: %v\n", url, err)
		unreachableChan <- url
		return
	}
	defer resp.Body.Close() // Ensure the response body is closed after all operations

	if resp.StatusCode != http.StatusOK {
		fmt.Printf("URL %s returned status code %d\n", url, resp.StatusCode)
		unreachableChan <- url
		return
	}
	reachableChan <- url
}

func main() {
	// 给 10 个 url 例子
	urls := []string{
		"https://www.baidu.com",
		"https://www.google.com",
		"https://www.bing.com",
		"https://www.yahoo.com",
		"https://www.yandex.com",
		"https://www.duckduckgo.com",
		"https://www.ask.com",
		"https://www.aol.com",
		"https://www.ask.com",
		"https://www.aol.com",
	}

	var wg sync.WaitGroup
	reachableChan := make(chan string, len(urls))
	unreachableChan := make(chan string, len(urls))
	for _, url := range urls {
		wg.Add(1)
		go checkUrl(url, &wg, reachableChan, unreachableChan)
	}
	wg.Wait()
	close(reachableChan)
	close(unreachableChan)
	//fmt.Println("resultChan:", resultChan)

	for url := range reachableChan {
		fmt.Println("通的url:", url)
	}

	for url := range unreachableChan {
		fmt.Println("不通的url:", url)
	}
}

  1. 项目

    1. 介绍一下我个人主页网站的架构。https://home.huchao.vip/。这就相当于一个应用,为什么能运行,肯定有一些机制,讲解一下背后的架构。
    2. https://home.huchao.vip/ 我的个人主页,点博客后,跳转到 https://blog.huchao.vip/ 我的个人博客页面。这中间发生了什么。
  2. 讲解一下公司ark方舟中台系统的架构设计

  3. 如果你接到工作,你对整个服务都不清楚,你是怎么开发的?

  4. 你做的是哪个服务?schedule-console,

  5. 详讲调度系统schedule-console

  6. 调度体现在哪?接收一些指令,然后去做一些工作

  7. 项目中,什么叫,利用Golang的并发特性和简洁语法实现高效的服务通信和数据处理逻辑。能细讲一下吗?

  8. 优化服务性能通过引入分布式缓存、负载均衡等技术﹐提升系统响应速度和可扩展性﹐预计服务性能提升30%以上

  9. mysql了解吗?你是怎么学的?有没有看过什么书?

总结:

  • 回答问题不用紧张,项目需要再熟悉,写的东西不管多还是少,只要写上了一定要了解,要有深度,不能只做开发,往上层要再想一想。
  • 又是0八股,项目是大头,项目的架构设计也是重点,不会啊。。。
#社招面试##Golang面经##项目##百度##Golang社招#
全部评论
老哥几年经验
点赞 回复 分享
发布于 07-11 20:56 广东

相关推荐

10-29 11:45
东北大学 C++
一面:操作系统下面有个proc目录,讲一下这个目录中管理的都是什么?运行中的进程都有一个以其&nbsp;PID&nbsp;为名的子目录,我要查看这个进程的CPU占用怎么看?top命令,它是怎么做到能看到整机资源的?现在写一些C++项目,部署到服务器上,他现在出现了OM,它被cue了,那这个时候需要排查一下这个问题怎么排查?根据你了解的操作系统和命令的话如果有一个学生表student,有四个字段,student,score,age,class,求每个班age大于18的人数sql语句怎么写?讲解一下锁的可重入性介绍一下grpc,json和protobuf的实现、区别,应用场景。设计一个类似的应用场景。讲解一下MySQL的索引,有什么优点加索引之后查找方式?B+树场景下怎么进行的查表过程索引使用B+树它的优势是什么?假设我们对一个text字段做了索引,那么这个时候它的查找速度会不会快?如果快或者不快的话,它是一个怎么寻址的过程?比如说他在寻址过程中要二分,他是根据什么去做的?二分怎么做的排序?一张表中对性别见了索引,它的缺点是什么样子,数据呈现是什么样子,为什么他快不了?讲一下对拥塞控制的理解为什么要修改门限值?不修改门限会有什么问题?手撕:查找第K个最大值二面:groupcache和redis的区别是什么?讲一下你理解的SQL优化有哪些?为什么索引失效会影响性能?MySQL索引的存在形式是什么?在Linux上,僵尸进程是怎么形成的?讲解一下Go的GMP和垃圾回收机制Linux如何查看一个进程的信息?一般进程的信息都有哪些Linux系统里面他的文件权限系统是怎么样的?怎么控制它的文件权限,哪些值分别代表什么意思?一般655是什么权限?介绍一下TCP/IP网络模型手撕:用golang写一下你项目中的某一块核心代码(忘得差不多,提问不能cpp?&nbsp;面试官:只能golang,写的太烂挂&nbsp;)。
查看28道真题和解析
点赞 评论 收藏
分享
5 11 评论
分享
牛客网
牛客企业服务