golang实现通过索引删除任意类型的slice元素

最近在写练手项目的时候,需求一个功能: 实现通过数组或者切片的索引删除 任意类型数组或者切片的内容,并且返回删除后的结果集,找了半天发现 官方package中没有Java.util.Arrays 这样的工具类的实现,只好自己写一个 ,由于golang中没有c++ 、java中泛型的概念,所以只能将工具方法通过 反射类实现一下,具体代码如下:

package tools

import (
	"errors"
	"reflect"
)

//删除切片
func DeleteSlice(slice interface{},index int) (interface{},error) {
	sliceValue := reflect.ValueOf(slice)
	length := sliceValue.Len()
	if slice == nil || length == 0 || (length-1) < index {
		return nil,errors.New("error")
	}
	if length-1 == index {
		return sliceValue.Slice(0,index).Interface(),nil
	} else if (length - 1) >= index {
		return reflect.AppendSlice(sliceValue.Slice(0,index),sliceValue.Slice(index+1,length)).Interface(),nil
	}
	return nil,errors.New("error")
}



练手项目ActivedRouter https://github.com/UsherYue/ActivedRouter,求start

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...