草庐IT

INTERFACE

全部标签

go - 在 golang 中声明一个空的 map[string]interface{} 的内存成本/开销是多少?

这个问题在这里已经有了答案:MemoryoverheadofmapsinGo(5个答案)关闭3年前。出于好奇,来自sourcecodetypehmapstruct{countint//1wordflagsuint8Buint8noverflowuint16hash0uint32//=8bytebucketsunsafe.Pointer//1wordoldbucketsunsafe.Pointer//1wordnevacuateuintptr//1wordextra*mapextra//1word}所以它至少是:5字+8字节但为什么creationcostis0?-packagemain

go - dynamodbattribute.UnmarshalMap 将我的变量类型更改为 map[string]interface{}

背景我正在尝试将dynamodb.GetItem返回的项目解码到一个对象中,我在那个地方不知道是哪种类型。为此,我有一个函数emptyItemConstructor,它返回所需类型的新对象t。问题我有这样一个函数:funcGetItem(emptyItemConstructorfunc()interface{})interface{}{myItem:=emptyItemConstructor()fmt.Printf("Typeis:%T\n",myItem)_=dynamodbattribute.UnmarshalMap(item,&myItem)fmt.Printf("Typenow

interface - 类型上的 Golang 接口(interface)

我是GO的新手,我正在使用golang编写一个简单的类型接口(interface)。类型定义为:typeSequence[]float64andtheinterfaceis:typeStatsinterface{greaterThan(xfloat64)Sequence}函数greaterThan(xfloat64)应该返回一个与对象中的数字相同的新序列//除了所有小于或等于x的数字都已被删除。这是我的尝试,但无法编译。我不知道如何解决它。我的问题是:如何从结构类型中删除项目?我应该使用map吗?(作为我的尝试)packagemainimport"fmt"typeSequence[]f

interface - Go:工厂返回指针和接口(interface){}类型

考虑以下工厂:GoplaygroundtypeTypeAstruct{placeholderint}funcNewTypeA()*TypeA{returnnew(TypeA)}funcmain(){factory:=make(map[string]func()interface{})factory["TypeA"]=NewTypeA}这给了我以下错误:cannotuseNewTypeA(typefunc()*TypeA)astypefunc()interface{}inassignment这很清楚。我认为interface{}可以与指针匹配。我找到了这个解决方案:Goplaygroun

arrays - Go:如何在函数中获取 slice 的长度?

我有一个函数,我想向其提供不同类型的slice,之后我想遍历它们并打印它们的内容。以下代码有效:funcplot(datainterface{}){fmt.Println(data)//fmt.Println(len(data))}funcmain(){l:=[]int{1,4,3}plot(l)}但是,当我取消注释打印slice长度的那一行时,我收到一条错误消息:invalidargumentdata(typeinterface{})forlen。知道如何获取slice的长度以便循环遍历它吗? 最佳答案 您应该尽可能避免使用int

function - 如何使用 interface{} 作为灵活的函数参数和返回类型?

我是Go的初学者,我现在正在编写一个可以调用API的函数。该函数接收一部分url(/user、/account等)和将返回的json转换为的结构(结构User或Account作为参数。所以我现在有这个:func(self*RestClient)request(actionstring,return_typeinterface{})interface{}{res,_:=goreq.Request{Uri:self.url+action}.Do()varitemreturn_typeres.Body.FromJsonTo(&item)returnitem}我尝试使用(Index是返回类型的

go - go中的包解耦

我们都知道依赖注入(inject)使包解耦。但是我对go中依赖注入(inject)的最佳实践有点困惑。让我们假设包用户需要访问配置包。我们可以将Config对象传递给User方法。这样,只要新代码解析接口(interface),我就可以更改Config包功能。另一种方法是直接调用Config包方法,在这些情况下,只要方法名称保持不变,我也可以更改Config代码。像这样更新:这两种方法有什么不同:packageUserfuncfoo(configConfigObject){config.Foo()}还有这个:packageUserimportConfigfuncfoo(){config

go - 接口(interface)类型中的新功能不起作用

如果我有这样的接口(interface)类型:typeMessageinterface{New()*MessageGet()string}和这样的结构:typeEntitystruct{}func(e*Entity)New()*Entity{returne}func(eEntiy)Get()string{return"hi"}实体将不是消息类型,除非我删除New()*Message。有人可以向我解释为什么这不起作用和/或我的问题出在哪里吗? 最佳答案 Entity要实现你的接口(interface),它必须严格遵守接口(interf

go - 为什么我得到一个引用接口(interface)的空变量?

packagemainimport("fmt""net/http""sync""time")typemyInterfaceinterface{doFunc()bool}typemyStructstruct{myValuestringsimyInterface}funcnewStrcut(simyInterface)*myStruct{return&myStruct{si:si}}varmyS*myStructfuncmain(){myS=newStrcut(&newStrcut{})myS.myValue="test"ifmyS.doMyLogic(){return}}func(s*m

go - Golang 中的返回接口(interface)

假设我们想在error接口(interface)上扩展Error()函数。我们可以简单地创建一个从实现Error()方法的字符串派生的结构。例如:typeNewUserstruct{EmailstringPasswordstring}typeErrMissingFieldstringfunc(eErrMissingField)Error()string{returnstring(e)+"isrequired"}func(u*NewUser)OK()error{iflen(u.Email)==0{returnErrMissingField("email")}iflen(u.Passwor