news 2026/4/16 12:51:08

Go进阶之尽量定义小接口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Go进阶之尽量定义小接口

接口越大.抽象程度越低.

1.Go推荐定义小接口:

接口就是将对象的行为进行抽象形成的契约.契约有繁有简.Go选择了去繁就简.

1).契约的自动遵守:

Go语言中接口与其实现者之间的关系是隐式的.无须像其他语言(如java)那样要求实

现者显示放置implents声明.实现者仅需实现接口方法集中的全部方法.就算是自动

遵守了契约.实现了接口.

2).小契约:

契约繁了便束缚束脚.降低灵活性.抑制表现力.Go表现在代码上便是尽量定义小接口.

2.Go标准库定义的接口:

源码位置:src/builtin/builtin.go

// The error built-in interface type is the conventional interface for // representing an error condition, with the nil value representing no error. type error interface { Error() string }

源码位置:src/io/io.go

type Reader interface { Read(p []byte) (n int, err error) }

源码位置:src/net/http/server.go

type ResponseWriter interface { Header() Header Write([]byte) (int, error) WriteHeader(statusCode int) }

可以看到上面的接口的方法数量为1~3个这种小接口的最佳实践已经被Go程序员和

各个社区项目广泛采用.

3.小接口的优势:

1).接口越小.抽象程度越高.被接纳度越高.

计算机程序本身就是对真实世界的抽象与在构建.抽象是对同类事物去除其个别的 次

要的方面.抽取其相同的 主要的方面的方法.不同的抽象程度会导致抽象出的概念对应

的事物集合不同.抽象程度越高.对应的空间集合越大.抽象程度越低(越具象.越接近事

物的真实面貌).对应的空间集合越小.

示例:

// 会飞的. type Flyable interface { Fly() } // 会游泳的. type Swimmable interface { Swim() } // 会飞会游泳的. type FlySwimmable interface { FlySwim() }

2).易于实现和测试.

3).契约职责单一.易于复用组合.

4.定义小接口遵循的点:

1).抽象出接口.

要设计和定义小接口.需要先有接口.在定义小接口之前.先需要理解问题域.然后创建

接口.

2).初期不要太在意接口的大小.

3).将大接口拆分为小接口.

我们有多少十年.又能舍得为十年付出多少呢.

如果大家喜欢我的分享的话,可以关注我的微信公众号

念何架构之路

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 20:22:47

格式工厂:老牌格式转换神器依旧能打!

下载链接 https://pan.freedw.com/s/lr763C 今天给大家推荐一款经典老牌软件格式工厂,虽然已经很多年了,但功能依旧强大到爆!支持视频、音频、图片、文档等各种格式转换,一个软件搞定所有需求,关键是还完全免费。 软…

作者头像 李华
网站建设 2026/4/15 22:22:50

写论文省心了!千笔AI,专科生论文写作神器

写论文省心了!千笔AI,专科生论文写作神器你是否曾为论文选题发愁,反复修改却总对内容不满意?是否在查重和格式上花费大量时间却收效甚微?专科生的论文之路本就充满挑战,而千笔AI正是为解决这些痛点而生。它以强大的AI技…

作者头像 李华
网站建设 2026/4/12 23:57:39

直接上结论:千笔ai写作,本科生论文救星!

直接上结论:千笔ai写作,本科生论文救星!你是否曾在论文写作中感到力不从心?选题无头绪、资料难查找、逻辑不清晰、查重率高得让人崩溃……这些看似“正常”的学术难题,其实早已被千笔AI破解。作为一款专为本科生量身打…

作者头像 李华
网站建设 2026/4/12 22:14:41

函数指针实战:冒泡排序与四则运算

函数指针的练习函数指针实现冒泡排序的升序和降序#include <stdio.h> #include <stdlib.h> #include <time.h> //正常升序 int shengxu(int* a,int len) {int i0;int j0;for(jlen-1;j>0;j--){for(i0;i<j;i){if(a[i]>a[i1]){int ta[i];a[i]a[i1];a[i…

作者头像 李华