基本上我有这个:
package main
import "fmt"
type Struct1 struct {
id int
name string
}
type Struct2 struct {
id int
lastname string
}
type Struct3 struct {
id int
real bool
}
func main() {
var (
s1 []Struct1
s2 []Struct2
s3 []Struct3
)
s1 = append(s1, Struct1{id: 1, name: "Eliot"}, Struct1{id: 2, name: "Tyrell"}, Struct1{id: 3, name: "Mr Robot"})
s2 = append(s2, Struct2{id: 1, lastname: "Anderson"}, Struct2{id: 2, lastname: "Wellick"})
s3 = append(s3, Struct3{id: 1, real: true}, Struct3{id: 2, real: true}, Struct3{id: 3, real: false})
}
我想展示这样的东西:
但我不想在 s2 中循环 s1,然后在 s3 中循环
例子:
for i := 0; i < len(s1); i++ {
for j := 0; j < len(s2); j++ {
if s1[i].id == s2[j].id {
for k := 0; k < len(s3); k++ {
if s2[j].id == s3[k].id {
// some code ...
}
}
}
}
}
那么,还有哪些其他方法可以做到这一点?
最佳答案
正确的方法是将它们放在一个散列中(在 Golang 中称为 map)。这样您可以获得性能,并且只需一个循环遍历 id 即可。
这是您的示例数据的示例:
package main
import (
"fmt"
)
type Struct1 struct {
id int
name string
}
type Struct2 struct {
id int
lastname string
}
type Struct3 struct {
id int
real bool
}
func main() {
//var (
//s1 []Struct1
// s2 []Struct2
// s3 []Struct3
// )
s1Hash := make(map[int]Struct1)
s2Hash := make(map[int]Struct2)
s3Hash := make(map[int]Struct3)
s11 := Struct1{id: 1, name: "Eliot"}
s12 := Struct1{id: 2, name: "Tyrell"}
s13 := Struct1{id: 3, name: "Mr Robot"}
s1Hash[s11.id] = s11
s1Hash[s12.id] = s12
s1Hash[s13.id] = s13
s21 := Struct2{id: 1, lastname: "Anderson"}
s22 := Struct2{id: 2, lastname: "Wellick"}
s2Hash[s21.id] = s21
s2Hash[s22.id] = s22
s31 := Struct3{id: 1, real: true}
s32 := Struct3{id: 2, real: true}
s33 := Struct3{id: 3, real: false}
s3Hash[s31.id] = s31
s3Hash[s32.id] = s32
s3Hash[s33.id] = s33
//s1 = append(s1, Struct1{id: 1, name: "Eliot"}, Struct1{id: 2, name: "Tyrell"}, Struct1{id: 3, name: "Mr Robot"})
//s2 = append(s2, Struct2{id: 1, lastname: "Anderson"}, Struct2{id: 2, lastname: "Wellick"})
//s3 = append(s3, Struct3{id: 1, real: true}, Struct3{id: 2, real: true}, Struct3{id: 3, real: false})
//i to loop over possible id range
for i := 1; i <= len(s1Hash); i++ {
fmt.Println("i is ", i)
if _, ok := s1Hash[i]; ok {
fmt.Printf("Name: %s ", s1Hash[i].name)
}
if _, ok := s2Hash[i]; ok {
fmt.Printf(" Lastname: %s ", s2Hash[i].lastname)
}
if _, ok := s3Hash[i]; ok {
fmt.Printf(" Real: %t\n", s3Hash[i].real)
}
//fmt.Printf("%s %s real:%t\n", s1Hash[i].name, s2[i].lastname, s3[i].real)
}
}
输出:
i is 1
Name: Eliot Lastname: Anderson Real: true
i is 2
Name: Tyrell Lastname: Wellick Real: true
i is 3
Name: Mr Robot Real: false
检查 this在 Playground 上。希望这对您有所帮助!
附注:最终,如果您可能删除某些 ID 的所有结构条目并添加更新的 ID - 您可以考虑将有效 ID 添加到映射 map[int]bool (mymap[id] = true) 并使用 range 代替上面的 for i.. 遍历 map 。
关于arrays - 在 go 中循环 slice/数组的有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47686910/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
我怎样才能完成http://php.net/manual/en/function.call-user-func-array.php在ruby中?所以我可以这样做:classAppdeffoo(a,b)putsa+benddefbarargs=[1,2]App.send(:foo,args)#doesn'tworkApp.send(:foo,args[0],args[1])#doeswork,butdoesnotscaleendend 最佳答案 尝试分解数组App.send(:foo,*args)
我脑子里浮现出一些关于一种新编程语言的想法,所以我想我会尝试实现它。一位friend建议我尝试使用Treetop(Rubygem)来创建一个解析器。Treetop的文档很少,我以前从未做过这种事情。我的解析器表现得好像有一个无限循环,但没有堆栈跟踪;事实证明很难追踪到。有人可以指出入门级解析/AST指南的方向吗?我真的需要一些列出规则、常见用法等的东西来使用像Treetop这样的工具。我的语法分析器在GitHub上,以防有人希望帮助我改进它。class{initialize=lambda(name){receiver.name=name}greet=lambda{IO.puts("He
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby数组,我们在StackOverflow上找到一
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]