草庐IT

工作制度

全部标签

Golang 结构数组不工作

我是golang的新手。我正在尝试获取数组中的用户详细信息。这是我的代码packagemainimport("fmt")typeuserstruct{namestringemailstring}funcmain(){u:=[]user{}u[0].name="Vanaraj"fmt.Println(u)}如何实现?提前致谢。非常感谢任何帮助。 最佳答案 它工作正常,但它是空的;尝试访问第一个元素(设置其字段)失败,不是因为数组不工作,而是因为没有第一个元素。用元素初始化它likethis:u:=[]user{user{name:"f

go - 如何应用 kubernetes 工作负载

我正在编写一个将在kubernetes集群中运行的Go程序。我希望程序使用yaml(json格式的yaml)应用kubernetes工作负载import("encoding/json""fmt"corev1"k8s.io/api/core/v1")var(workload=`{"apiVersion":"v1","kind":"Pod","metadata":{"name":"sleep",},"spec":{"containers":[{"name":"sleep2","image":"tutum/curl","command":["/bin/sleep","infinity"],"

golang string.ToLower 不工作

关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭4年前。Improvethisquestion我有一个简单的输入字符串,我需要读取它并计算重复的单词。但是,在执行此操作时我需要将字符串转换为小写,但有些功能ToLower无法正常工作。我附上了golang链接,请帮助我了解可能是什么问题。https://play.golang.org/p/OnQW-pgQxqq同时粘贴代码。funcmain(

go - 无法让接口(interface)片段工作

我想做的是创建一个interface类型的slice,并用一些实现此接口(interface)的结构类型填充它。chans:=[]chanEvent{make(chanFileEvent),make(chanNetworkEvent),}但这失败了cannotusemake(chanFileEvent)(typechanFileEvent)astypechanEventinarrayorsliceliteral。现在我知道这是meanttobethatway.然而,建议的解决方案是a)不切实际,因为我有一堆不同的类型,无法轻易地迭代它们,并且b)我什至无法让它工作,它仍然给我同样的错误

go - 了解内存分配的工作原理和垃圾收集器

假设我正在为多个演出制作内存缓存。为了在缓存达到最大大小时释放空间,我将删除不经常访问的项目。当我删除这些项目时,是否会释放内存以供计算机分配给其他进程和/或我的应用程序?我知道Go使用垃圾收集器,所以大概操作系统在垃圾收集之前无法访问该内存,然后我的应用程序将消耗更少的内存资源。这是正确的吗? 最佳答案 您将如何删除项目?Comment:soifIamstoringtheitemsinasliceIwoulddoa=append(a[:i],a[i+1:]...)–Blankman哪个可能有效也可能无效。slice是什么类型?Go

go - os.Read() 是如何工作的?戈朗

为什么如果我打印bs,在调用Read()之前,它什么都不打印,但在调用file.Read(bs)之后,它显示了test.txt文件的内部。除非bs只是参数,Read()如何改变它?packagemainimport("os""fmt")funcmain(){file,err:=os.Open("test.txt")iferr==nil{}else{}stat,_:=file.Stat()bs:=make([]byte,stat.Size())fmt.Println(string(bs))bsf,err:=file.Read(bs)iferr!=nil{fmt.Println(err)f

linux - 在 bash 脚本中不工作“source ~/.profile”

要使用源代码永久更新~/.profile,仅适用于手动输入。整个系统重启也不会更新~/.profile,我需要手动更新它。是否有一种特殊的代码风格可以将其用作bash/shell脚本中的工作代码,或者这种特殊代码是否不适用于自动化脚本?需要它来自动安装golang。在下面的代码中,“source~/.profile”行将不起作用,并且没有任何错误消息,其余部分工作正常:#!/bin/bashsudoaptupdatesudoapt-yupgradecd~curl-Ohttps://dl.google.com/go/go1.12.5.linux-amd64.tar.gztarxvfgo1

go - “附加”的工作方式是什么?

我想逐行读取文件,并且每一行可能都有很多字符。这个版本的readline效果很好funcreadLine(r*bufio.Reader)([]byte,error){var(isPrefix=trueerrerrorline,ln[]byte)forisPrefix&&err==nil{line,isPrefix,err=r.ReadLine()ln=append(ln,line...)}returnln,err}但是另一个不起作用funcreadLine(r*bufio.Reader)([]byte,error){line,isprefix,err:=r.ReadLine()fori

git - `go get` 首先失败,然后工作

go命令gogetgithub.com/cloudnativego/gogo-service/service第一次失败,但在第二次运行时通过了。整个事件序列:[23:47]$gogetgithub.com/cloudnativego/gogo-service/service#cd/Users/../github.com/cloudnativego/gogo-service;gitsubmoduleupdate--init--recursiveNosubmodulemappingfoundin.gitmodulesforpath'vendor/github.com/cloudfoundr

go - 了解缓冲 channel 的工作原理

谁能给我解释一下channel在这些场景中是如何工作的:如果channel没有缓冲,如果您在尚未收到任何消息时向channel2发送消息,它是否会阻止应用程序?如果有缓冲区,一旦达到缓冲量,它的行为就像#1?因此,如果缓冲区为2,则在2条消息之后它会阻塞,直到您收到至少1条消息?既然你必须设置缓冲量,你不能只有一个channel来存储任意数量的消息吗? 最佳答案 是的。是的。不,您不能拥有无限缓冲的channel。详细介绍intheGotour.基本上,无论何时例程在channel上发送,该例程都会阻塞,直到某物可用于接收它。这可能