广告
返回顶部
首页 > 资讯 > 后端开发 > GO >Golang中slice删除元素的性能对比
  • 373
分享到

Golang中slice删除元素的性能对比

2024-04-02 19:04:59 373人浏览 独家记忆
摘要

目录我的电脑配置:直接上代码:Benchmark结果:解释:总结在我写的blog中,这个算是参与度比较高的,所以有必要把程序写的更加容易理解一些。 我的电脑配置: ☁  b

在我写的blog中,这个算是参与度比较高的,所以有必要把程序写的更加容易理解一些。

我的电脑配置:

☁  bechmark  system_profiler SPHardwareDataType
Hardware:

    Hardware Overview:

      Model Name: MacBook Pro
      Model Identifier: MacBookPro14,1
      Processor Name: Dual-Core Intel Core i5
      Processor Speed: 2.3 GHz
      Number of Processors: 1
      Total Number of Cores: 2
      L2 Cache (per Core): 256 KB
      L3 Cache: 4 MB
      Hyper-Threading Technology: Enabled
      Memory: 8 GB
      Boot ROM Version: 428.0.0.0.0
      SMC Version (system): 2.43f10

直接上代码:

package bechmark

import (
    "testing"
)

var (
    // 原始slice
    origin = []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
    // 需要删除的元素
    targetEle = 6
)

// 第一种
func BenchmarkMake(t *testing.B) {
    t.ResetTimer()

    for i := 0; i < t.N; i++ {
        target := make([]int, 0, len(origin))
        for _, item := range origin {
            if item != targetEle {
                target = append(target, item)
            }
        }
    }
}

// 第二种
func BenchmarkReuse(t *testing.B) {
    t.ResetTimer()

    for i := 0; i < t.N; i++ {
        target := origin[:0]
        for _, item := range origin {
            if item != targetEle {
                target = append(target, item)
            }
        }
    }
}

// 第三种
func BenchmarkEditOne(t *testing.B) {
    t.ResetTimer()

    for i := 0; i < t.N; i++ {
        for i := 0; i < len(origin); i++ {
            if origin[i] == targetEle {
                origin = append(origin[:i], origin[i+1:]...)
                i-- // maintain the correct index
            }
        }
    }
}

Benchmark结果:

☁  bechmark  Go test -v -bench=. -benchtime=3s -benchmem
goos: darwin
goarch: amd64
pkg: test/bechmark
BenchmarkMake-4         95345845            35.8 ns/op        80 B/op          1 allocs/op
BenchmarkReuse-4        255912920           14.4 ns/op         0 B/op          0 allocs/op
BenchmarkEditOne-4      473434452            7.56 ns/op        0 B/op          0 allocs/op
PASS
ok      test/bechmark   12.915s

解释:

  • 除了第一种方法外,其他方法都对原数据进行了修改;
  • 第一种方法适合不污染原slice数据的情况下使用,这种方式也比较简单,大部分学习golang的人也都能想到,不过性能稍差一些,还存在内存分配情况,不过也要看业务需要;
  • 第二种方法比较巧妙,也是看到一个大神写的,创建了一个slice,但是共用原始slice的底层数组;这样就不需要额外分配内存空间,直接在原数据上进行修改。
  • 第三种方法也会对底层数组进行修改,思路和前两种正好相反,如果找到需要移除的元素的时候,将其之后的元素前移,覆盖该元素的位置。

总结

到此这篇关于Golang中slice删除元素的性能对比的文章就介绍到这了,更多相关Golang slice删除元素内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Golang中slice删除元素的性能对比

本文链接: https://www.lsjlt.com/news/152986.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Golang中slice删除元素的性能对比
    目录我的电脑配置:直接上代码:Benchmark结果:解释:总结在我写的blog中,这个算是参与度比较高的,所以有必要把程序写的更加容易理解一些。 我的电脑配置: ☁  b...
    99+
    2022-11-13
  • Golang中slice删除元素的性能实例对比分析
    本篇内容主要讲解“Golang中slice删除元素的性能实例对比分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Golang中slice删除元素的性能实例对比分析”吧!我的电脑配置:☁ &nb...
    99+
    2023-07-02
  • Golang中如何删除slice元素
    Golang是一种高效的编程语言,它有着强大的内存管理能力。在Golang开发中,我们经常会用到slice,它是Golang中最常用的数据结构之一。slice可以看作是一个动态数组,它有着灵活的大小和容量,因此在开发过程中非常方便。不过,处...
    99+
    2023-05-14
    slice go语言 Golang
  • Golang中怎么删除slice元素
    本文小编为大家详细介绍“Golang中怎么删除slice元素”,内容详细,步骤清晰,细节处理妥当,希望这篇“Golang中怎么删除slice元素”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一. 什么是slice...
    99+
    2023-07-05
  • 详解Golang中删除slice元素的几种方法
    Golang是一种流行的编程语言,因为它简单、高效和易于学习。当你在使用Golang进行编程时,你可能会遇到需要从slice中删除元素的情况。在这篇文章中,我们将会讨论在Golang中删除slice元素的几种方法。方法一:使用append函...
    99+
    2023-05-14
  • Golang切片删除指定元素的三种方法对比
    目录前言1.截取法(修改原切片)2.拷贝法(不改原切片)3.移位法(修改原切片)3.1 方式一3.2 方式二4.性能对比5.小结前言 Go 并没有提供删除切片元素专用的语法或函数,需...
    99+
    2022-11-13
  • Golang怎么删除数组中的元素
    Golang可以通过创建一个新的切片的方法来删除数组中的元素。详细介绍:1、判断索引是否越界;2、创建一个新的切片;3、拷贝删除元素后的数据到新的切;4、创建一个数组;5、删除索引为2的元素;6、输出结果即可。本教程操作系统:windows...
    99+
    2023-12-12
    go语言 Golang
  • jquery如何删除元素对象的属性
    本篇内容介绍了“jquery如何删除元素对象的属性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • 总结Golang中删除切片元素的常用方法
    在Golang中,切片是一种非常常用的数据类型。在进行数据处理时,我们常常会遇到需要删除切片中某些元素的情况。本文将介绍Golang中常用的删除切片元素的方法。一、使用append函数删除切片元素在Golang中,使用append函数可以对...
    99+
    2023-05-14
  • Golang中删除切片元素的常用方法有哪些
    这篇文章主要介绍“Golang中删除切片元素的常用方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang中删除切片元素的常用方法有哪些”文章能帮助大家解决问题。一、使用append函数...
    99+
    2023-07-05
  • javascript中怎么删除数组或对象中的元素
    这期内容当中小编将会给大家带来有关javascript中怎么删除数组或对象中的元素,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、数组:代码: function&nbs...
    99+
    2022-10-19
  • javascript中如何删除元素中的指定属性
    javascript中如何删除元素中的指定属性,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。在JavaScript中,可以使用removeAt...
    99+
    2022-10-19
  • Java基础之List内元素的排序性能对比
    目录一、概述二、按条件排序几种方案及性能对比2.1 利用集合框架提供的Collections.sort实现排序2.2 实现Comparable接口2.3 利用JAVA 8 strea...
    99+
    2022-11-12
  • Python列表对象中元素的删除操作方法
    目录1.列表元素删操作的方法2.调用remove方法一次删除一个指定的元素3.调用pop方法一次只删除一个指定索引的元素3.1.使用pop方法删除列表中索引为2的元素3.2.使用po...
    99+
    2022-12-21
    Python列表元素删除操作 Python列表操作 Python列表元素
  • jquery如何删除多个元素中的class属性
    这篇文章主要讲解了“jquery如何删除多个元素中的class属性”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“jquery如何删除多个元素中的class属...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作