前言

这是青训营的第一课,今天的课程比较快速的讲解了go语言的入门,并配合三个小的项目实践梳理所学知识点,这里详细回顾一下这三个项目,结合课后作业要求做一些代码补充,并附上自己的分析,青训期间的所有课程笔记会同步文末公众号,有需要同学请关注~。

项目仓库地址:https://github.com/wangkechun/go-by-example

实战

项目一:guessing-game

生成一个100以内随机数,玩家在控制台输入猜测的数字,程序会不断反馈猜测的值与生产值的大小关系,直到玩家输入正确,代码简单,这里直接贴出(需要注意不要忘记添加随机数种子):

项目二:simpledict

先概述一下功能:用户将需要翻译的单词作为参数在命令行运行go的main函数,程序会返回翻译结果。通过下面的语句可以直接运行样例仓库代码中的main函数,得到翻译结果。

那么程序是如何实现这个翻译功能的呢?它做了下面几件事:

  • 获取main函数运行时的参数hello作为需要翻译的单词(通过go的api获取)

  • 请求翻译软件的api获取结果数据:

    • 这个过程和爬虫的工作比较像,模拟用户在网页上提交翻译的请求,其本质上就是发送了一个http请求,携带需要翻译的单词信息,响应翻译结果的json并由浏览器解析,通过下图的copy as cURL可以将本次request的请求以cURL请求的方式拷贝。

    • 访问:https://curlconverter.com/#go,这个在线工具可以将curl命令转换成go语言代码(或者其他语言),将得到的代码直接复制到goland中运行就可以实现用go代码模拟请求这个翻译接口,得到响应数据(文本格式的json)

  • 解析结果数据

    • 此时得到的翻译数据是文本格式的json(就是byte数组,或者说字符串),因此需要将其反序列化为go的结构体,然后打印出我们需要的翻译信息。

    • 访问:https://oktools.net/json2go,这个在线工具可以将json转go的struct,然后将这个结构放入go代码中,使用json包的Unmarshal函数将json字符串字符串反序列化为结构体,后面就可以打印结构体中需要的属性(包含翻译结果)

  • 改进:用到两个翻译软件的接口,并且并发访问,思路是一样的,就是再找一个翻译软件的接口重复上面的操作,然后重点在于并发的实现,这里启用两个goroutine,借助sync包的WaitGroup,先初始化一个2的容量,然后在一个go程结束之后调用wg.Done(),只有全部容量次数的Done调用后wg.Wait()才会放行,否则任意一个go程未完成,主go程都不会继续执行(但是如果没有这个WaitGroup去限制,则在主go程结束时,因为由其创建的子go程可能并没有完成,但依旧会结束,而恰恰因为并发的关系,编码先后顺序的失去了作用,发生这种情况的概率很高)

项目三:proxy

实现一个简易版的socks5的代理服务器,代理的工作流程如下:

  • 本质就是客户端要先和代理服务器建立TCP连接,然后socks代理服务器和需要访问的目标服务器建立TCP连接,对于所有从客户端发来的请求由代理服务器转发给目标服务器,且目标服务器的响应数据也由代理服务器转发给客户端(socks5代理服务器就是以sock5s协议为标准去建立客户端和代理服务器的通信)

  • 观察proxy项目包的v4版本(clone地址已经给出),看到代理服务端的process函数如下:

    • 代理的工作由auth()认证和connect()连接两个部分组成,看一下最上面给出的代理工作流程图,可以看到对应着协商阶段和通信阶段。而我们发现,本实例的客户端发起的是一条curl --socks5 127.0.0.1:1080 -v https://www.qq.com,需要注意的细节是,auth和connect工作并不是一蹴而就的,它们从reader缓冲区读取客户端发送过来的数据,验证之后返回给客户端,然后再获取从客户端发送过来的数据,而客户端的这部分工作已经被curl工具隐藏,而非只是发起了一次请求。
    • 因为auth和connect函数中多次使用到的从缓冲区读取字节的这个api在缓冲区没有byte的时候,是会被阻塞的,因此会等待客户端发送数据,因此只要代理服务器遵守socks5协议规定的通信规则进行解析客户端的数据,发送指定的响应,而客户端也遵守这个规则解析和发送数据(本例就是curl --socks5 xxx帮我们完成了),就可以实现socks5代理服务器的工作模式
    • 因此我理解中的socks5代理服务器就是完全在socks5协议约束的基础上进行编码的一个服务器,之后的请求和响应转发则和socks5没关系了

结束语

对于第三个样例这里只是着重讲了一下我的一些理解,socks5代理部分还有很多值得深入学习的地方。关于后面课程的学习,也尽量会保证笔记的输出,欢迎各位一起探讨学习~

关注微信公众号【程序员白泽】,将同步更新字节青训营的学习笔记

三个小项目入门Go语言|字节青训营笔记的更多相关文章

  1. 痞子衡嵌入式:我的三个小项目陆续上线恩智浦官方Github

    恍如眨眼间,痞子衡在飞思卡尔/恩智浦已经工作 8 年多了,前 5 年主要是在软件团队,最近 3 年在系统团队.所处团队不同,工作思维也不同,自从转到系统团队,开始跟客户打起交道,对待问题和解决问题的立 ...

  2. 小项目特供 贪吃蛇游戏(基于C语言)

    C语言写贪吃蛇本来是打算去年暑假写的,结果因为ACM集训给耽搁了,因此借寒假的两天功夫写了这个贪吃蛇小项目,顺带把C语言重温了一次. 是发表博客的前一天开始写的,一共写了三个版本,第一天写了第一版,第 ...

  3. C 语言快速入门,21 个小项目足矣!「不走弯路就是捷径」

    C 语言作为大学理工科专业的必修,是很多同学走进编程世界的第一课.那么怎样才能更好的入门 C 语言呢? 下面整理了 21 个 C 语言练手项目,从基础语法开始,逐步深入,通过一个个练手项目,让你轻松驰 ...

  4. C语言实现简单计算器小项目

    昨天刚安装上devc++,半夜想着练练C语言吧 于是就看到实验楼有一个计算器的项目 之前做过一次,这次写的主要是思路 首先我们先从原理思考jia,实现简单的计算器就要具备加减乘除这些,看普通的计算器也 ...

  5. Vue小项目二手书商城:(三)前端渲染数据

    实现内容: axios取到的数据在前端使用(父子组件各自应该怎么使用) 一.简单使用(在哪取在哪用) 1.在App.vue中script中加上data(data专属于当前组件,父子组件传参通过prop ...

  6. Java学习笔记三十:Java小项目之租车系统

    Java小项目之租车系统 一:项目背景介绍: 根据所学知识,编写一个控制台版的“呱呱租车系统” 功能: 1.展示所有可租车辆: 2.选择车型.租车量: 3.展示租车清单,包含:总金额.总载货量以及其车 ...

  7. 微信小程序入门与实战 常用组件API开发技巧项目实战*全

    第1章 什么是微信小程序? 第2章 小程序环境搭建与开发工具介绍 第3章 从一个简单的“欢迎“页面开始小程序之旅 第4章 第二个页面:新闻阅读列表 第5章 小程序的模板化与模块化 第6章 构建新闻详情 ...

  8. 【源码项目+解析】C语言/C++开发,打造一个小项目扫雷小游戏!

    一直说写个几百行的小项目,于是我写了一个控制台的扫雷,没有想到精简完了代码才200行左右,不过考虑到这是我精简过后的,浓缩才是精华嘛,我就发出来大家一起学习啦,看到程序跑起来能玩,感觉还是蛮有成就感的 ...

  9. 天河微信小程序入门《三》:打通任督二脉,前后台互通

    原文链接:http://www.wxapp-union.com/forum.php?mod=viewthread&tid=505&extra=page%3D1 天河君在申请到https ...

随机推荐

  1. Swing 是线程安全的?

    不是,Swing 不是线程安全的.你不能通过任何线程来更新 Swing 组件,如 JTable.JList 或 JPanel,事实上,它们只能通过 GUI 或 AWT 线程来更新. 这就是为什么 Sw ...

  2. 有没有可能两个不相等的对象有有相同的 hashcode?

    有可能,两个不相等的对象可能会有相同的 hashcode 值,这就是为什么在 hashmap 中会有冲突.相等 hashcode 值的规定只是说如果两个对象相等,必 须有相同的 hashcode 值, ...

  3. Mybatis-Plus 如何实现一对多关系 举例 用户与角色

    Mybatis-Plus 一对多Mybatis-Plus 不写一句sql语句实现一对多 首先来看效果 Mysql数据库 用户表 角色表 用户与角色的中间表 中间表如下 将三张表通过Mybatis Pl ...

  4. Rust 中的数据布局--非正常大小的类型

    非正常大小的类型 大多数的时候,我们期望类型在编译时能够有一个静态已知的非零大小,但这并不总是 Rust 的常态. Dynamically Sized Types (DSTs) Rust 支持动态大小 ...

  5. H5进阶篇--实现微信摇一摇功能

    在HTML5中,DeviceOrientation特性所提供的DeviceMotion事件封装了设备的运动传感器时间,通过改时间可以获取设备的运动状态.加速度等数据(另还有deviceOrientat ...

  6. [译] Facebook:我们是如何构建第一个跨平台的 React Native APP

    英文原文(需FQ):https://code.facebook.com/posts/1189117404435352/ 早些时候,我们介绍过iOS版的React Native. React Nativ ...

  7. 7步学会在Windows下上架iOS APP流程

    之前用跨平台开发工具做了一个应用,平台可以同时生成安卓版和苹果版,想着也把这应用上架到App Store试试,于是找同学借了个苹果开发者账号,但没那么简单,还要用到Mac电脑的钥匙串申请发布证书和上传 ...

  8. 【Android开发】【布局】 仿微信UI

    Demo地址

  9. uniapp最简单的上拉加载更多demo

    data() { return { list:[],//数据列表 page: 1,//页数 } }, //请求一下数据(进入页面请求一次) onLoad() { this.getnewsList(th ...

  10. JavaScript 字符串(String)对象的方法

    anchor() 描述:用于创建 HTML 锚 原型:stringObject.anchor(anchorname) 用法: <script> var txt="Hello wo ...