mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-11 11:20:38 +00:00
Merge pull request #559 from nspcc-dev/feature/stack_limits
vm: don't refcount simple items Improves 1.4M to 1.5M 100K mainnet block import test by ~4%.
This commit is contained in:
commit
33958be45f
1 changed files with 31 additions and 26 deletions
|
@ -214,19 +214,21 @@ func (s *Stack) insert(e, at *Element) *Element {
|
||||||
func (s *Stack) updateSizeAdd(item StackItem) {
|
func (s *Stack) updateSizeAdd(item StackItem) {
|
||||||
*s.size++
|
*s.size++
|
||||||
|
|
||||||
s.itemCount[item]++
|
switch item.(type) {
|
||||||
if s.itemCount[item] > 1 {
|
case *ArrayItem, *StructItem, *MapItem:
|
||||||
return
|
if s.itemCount[item]++; s.itemCount[item] > 1 {
|
||||||
}
|
return
|
||||||
|
|
||||||
switch t := item.(type) {
|
|
||||||
case *ArrayItem, *StructItem:
|
|
||||||
for _, it := range item.Value().([]StackItem) {
|
|
||||||
s.updateSizeAdd(it)
|
|
||||||
}
|
}
|
||||||
case *MapItem:
|
|
||||||
for _, v := range t.value {
|
switch t := item.(type) {
|
||||||
s.updateSizeAdd(v)
|
case *ArrayItem, *StructItem:
|
||||||
|
for _, it := range item.Value().([]StackItem) {
|
||||||
|
s.updateSizeAdd(it)
|
||||||
|
}
|
||||||
|
case *MapItem:
|
||||||
|
for _, v := range t.value {
|
||||||
|
s.updateSizeAdd(v)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -234,21 +236,24 @@ func (s *Stack) updateSizeAdd(item StackItem) {
|
||||||
func (s *Stack) updateSizeRemove(item StackItem) {
|
func (s *Stack) updateSizeRemove(item StackItem) {
|
||||||
*s.size--
|
*s.size--
|
||||||
|
|
||||||
if s.itemCount[item] > 1 {
|
switch item.(type) {
|
||||||
s.itemCount[item]--
|
case *ArrayItem, *StructItem, *MapItem:
|
||||||
return
|
if s.itemCount[item] > 1 {
|
||||||
}
|
s.itemCount[item]--
|
||||||
|
return
|
||||||
delete(s.itemCount, item)
|
|
||||||
|
|
||||||
switch t := item.(type) {
|
|
||||||
case *ArrayItem, *StructItem:
|
|
||||||
for _, it := range item.Value().([]StackItem) {
|
|
||||||
s.updateSizeRemove(it)
|
|
||||||
}
|
}
|
||||||
case *MapItem:
|
|
||||||
for _, v := range t.value {
|
delete(s.itemCount, item)
|
||||||
s.updateSizeRemove(v)
|
|
||||||
|
switch t := item.(type) {
|
||||||
|
case *ArrayItem, *StructItem:
|
||||||
|
for _, it := range item.Value().([]StackItem) {
|
||||||
|
s.updateSizeRemove(it)
|
||||||
|
}
|
||||||
|
case *MapItem:
|
||||||
|
for _, v := range t.value {
|
||||||
|
s.updateSizeRemove(v)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue