草庐IT

手工分配

全部标签

c - 将 C 翻译成 Golang。如何分配内存以匹配 C?

所以我正在翻译我在C中创建的程序。这个程序的目标是简单地从文件中读取矩阵,以稀疏行格式压缩矩阵,然后计算矩阵vector乘积。这是C语言的程序片段。//ReadtheMatrixMarketfileandinitializeaCSRformattedmatrix.csr_load_matrix(fileName,&compressedSparseMatrix);//Setthecorrectvaluestothestructandcreatethememoryallocation.double*x;double*y;x=malloc(compressedSparseMatrix.col

go - 您可以通过 virtual.go :EditObject()? 编辑 vdi 带宽分配吗

我正在使用此脚本的修改版本:https://softlayer.github.io/go/edit_virtual_guest.go/脚本是一样的,除了我的objectTemplate看起来像:varobjectTemplatedatatypes.Virtual_GuestobjectTemplate.BandwidthAllocation=sl.Float(250)运行后的输出是“VirtualGuestServerwassuccessfullyedited”但是我的vsi没有在ui中显示更新的带宽。是否可以使用EditObject调用来编辑带宽?是否可以使用不同的API调用来编辑带

go - 如何在创建软层 vsi 期间分配固定 IP 地址

如何在创建虚拟服务器时配置固定IP地址而不是分配动态IP地址。我使用了下面的代码,但它对我不起作用。请建议配置固定ip地址的最佳方法。代码:sess:=session.New(username,apikey)//GettheVirtual_Guestserviceservice:=services.GetVirtualGuestService(sess)//CreateaVirtual_GueststructasatemplatevGuestTemplate:=datatypes.Virtual_Guest{//SetCreationvalues-usehelpersfromthesl

go - Go中的同时变量分配不同于单个变量分配

我的印象是,尽管在语法上存在差异,但下面的函数a和函数b在逻辑上是等价的。但是,他们不是,我不明白他们之间的区别。在我看来,他们都在分配:变量z的x值,变量x的y值,以及x+y到变量y的值。有谁能帮我澄清关于多变量赋值和函数a和函数b之间逻辑差异的误解吗?packagemainimport"fmt"funca()(int,int,int){x:=1y:=2z:=3z=xx=yy=x+yreturnx,y,z}funcb()(int,int,int){x:=1y:=2z:=3z,x,y=x,y,x+yreturnx,y,z}funcmain(){fmt.Println(a())//pri

go - 删除 slice 中未分配的(零值)

如何删除所有零值或未分配的值?这里将堆栈跟踪放入slice中。如何删除所有未分配(零值)?是否有一些奇特的函数来slice......类似于字符串的子字符串trace:=make([]byte,1024)runtime.Stack(trace,true) 最佳答案 使用sliceexpression修剪堆栈缓冲区的未使用部分。Stack函数可以方便地返回写入缓冲区的字节数。trace:=make([]byte,1024)n:=runtime.Stack(trace,true)trace=trace[:n]playgroundlink

使用接口(interface)和动态类型进行变量分配

我有一个脚本,它根据用户输入从不同的数据源中提取数据,具有通用界面和每个数据源的类型。然后每个数据源都有一个方法来获取该特定源的元数据。我有点难以理解idomaticGo实现根据输入切换类型。这个例子不能编译,但它是最能说明我想做什么的版本:typePostinterface{GetMetadata()bool}typeYouTubeVideostruct{IDstringTitlestringChannelIDstringChannelTitlestringPublishedAtstring}func(ig*YouTubeVideo)GetMetadata()bool{//...}t

go - 无法使用 golang 和 net/http 包分配请求的地址

我在golang中有这个服务器:packagemainimport("fmt""net/http")funchello(whttp.ResponseWriter,r*http.Request){w.WriteHeader(204)fmt.Fprintf(w,"Hithere,Ilove%s!",r.URL.Path[1:])w.Header().Set("Connection","close")fmt.Println(r.Close)}funcmain(){http.HandleFunc("/",hello)http.ListenAndServe(":8080",nil)}然后我想尝试

memory-management - bytes.Buffer 是否执行大量重新分配?

我想做的是有一个io.MultiWriter写入标准输出和字节缓冲区。像这样:packagemainimport"bytes"import"fmt"import"io"import"os"funcmain(){varbbytes.Buffermulti:=io.MultiWriter(&b,os.Stdout)fmt.Fprintf(multi,"eachofthesestrings\n")fmt.Fprintf(multi,"mightbelarge\n")fmt.Fprintf(multi,"andtherearemanyofthem\n")fmt.Println(b.String

go - 如何分配内存以映射指向golang中的 slice

有没有办法分配映射的内存,最多有Nmax个键,指向最大长度Nmax的slice?我目前只是通过make(map[int][]int,Nmax)指定键的最大数量,但我不确定如何告诉Go每个slice将是最大长度Nmax因为我不知道key是先验的。我基本上有一堆人口为整数的网站。我使用map来跟踪有多少站点具有给定的人口N。我的程序中的瓶颈似乎是runtime.memmove,我猜这是由于不断调整map指向的slice的大小。 最佳答案 鉴于您对问题的描述确实相当模糊,我将首先说明我将如何“管理”map。为简单起见,我将把所有逻辑包装在

pointers - 分配嵌入的 Struct 类型值

假设我有以下结构:typeXstruct{NamestringAgeintEmailstring}然后我有2个其他结构(子类):typeAstruct{*X}typeBstruct{*X}然后在我的主要代码中我有:a:=A{&X{"John",34,"jd@email.com"}}b:=B{&X{"Greg",22,"gd@email.com"}}fmt.Println(a.Name)//Johnfmt.Println(b.Name)//Greg是否有一种简单的方法来分配a=b以便a.Name返回Greg以及所有其他属性(我不想单独分配它们,因为有一堆属性)注意:我必须这样做,因为我有