{"id":201,"date":"2024-09-12T15:39:58","date_gmt":"2024-09-12T08:39:58","guid":{"rendered":"https:\/\/gotutorial.org\/?page_id=201"},"modified":"2024-09-25T20:30:16","modified_gmt":"2024-09-25T13:30:16","slug":"go-slice","status":"publish","type":"page","link":"https:\/\/www.gotutorial.org\/go-tutorial\/go-slice\/","title":{"rendered":"Go Slice"},"content":{"rendered":"\n<p><strong>Summary<\/strong>: in this tutorial, you&#8217;ll learn about the Go slice and how to use it effectively.<\/p>\n\n\n\n<p>In Go, slices are like <a href=\"https:\/\/gotutorial.org\/go-tutorial\/go-arrays\/\">arrays<\/a> but have a dynamic size. By definition, a slice is a dynamically sized, flexible view into elements of an array.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Declaring a slice<\/h2>\n\n\n\n<p>To declare a slice, you use the <code>var<\/code> keyword, slice name, square brackets, and the type of the elements:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">var<\/span> sliceName &#91;] <span class=\"hljs-keyword\">type<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>This syntax is similar to <a href=\"https:\/\/gotutorial.org\/go-tutorial\/go-arrays\/\">declaring an array<\/a> except that it does not have a fixed size. Therefore, we don&#8217;t have to specify the size in the square brackets. For example:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">var<\/span> names &#91;] <span class=\"hljs-keyword\">string<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>This example declares the <code>names<\/code> slice that will store a list of strings.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Initializing a slice<\/h2>\n\n\n\n<p>You can declare and initialize a slice in a single line of code like this:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-3\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">var<\/span> names &#91;] <span class=\"hljs-keyword\">string<\/span> = &#91;] <span class=\"hljs-keyword\">string<\/span> {<span class=\"hljs-string\">\"Alice\"<\/span>, <span class=\"hljs-string\">\"Bob\"<\/span>, <span class=\"hljs-string\">\"John\"<\/span>}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-3\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Inside a function, you can use the short variable declaration to declare and initialize a slice:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-4\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\">names := &#91;] <span class=\"hljs-keyword\">string<\/span> {<span class=\"hljs-string\">\"Alice\"<\/span>, <span class=\"hljs-string\">\"Bob\"<\/span>, <span class=\"hljs-string\">\"John\"<\/span>}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-4\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Typically, you create a slice from an array. For example:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-5\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">package<\/span> main\n\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"fmt\"<\/span>\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">func<\/span> <span class=\"hljs-title\">main<\/span><span class=\"hljs-params\">()<\/span><\/span> {\n    guests := &#91;<span class=\"hljs-number\">3<\/span>] <span class=\"hljs-keyword\">string<\/span>{<span class=\"hljs-string\">\"Alice\"<\/span>, <span class=\"hljs-string\">\"Bob\"<\/span>, <span class=\"hljs-string\">\"John\"<\/span>}\n    vip := guests&#91;<span class=\"hljs-number\">0<\/span>:<span class=\"hljs-number\">2<\/span>]\n\n    <span class=\"hljs-keyword\">for<\/span> index, name := <span class=\"hljs-keyword\">range<\/span> vip {\n        fmt.Println(index, name)\n    }\n}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-5\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Output:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-6\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-number\">0<\/span> Alice\n<span class=\"hljs-number\">1<\/span> Bob<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-6\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>In this example, we create a slice <code>vip<\/code> from the <code>guests<\/code> array. The <code>vip<\/code> slice includes the first and second elements of the <code>guests<\/code> array. <\/p>\n\n\n\n<p>The <a href=\"https:\/\/gotutorial.org\/go-tutorial\/go-for-range\/\">for range<\/a> iterates over elements of the <code>vip<\/code> slice and displays their indexes and values on the screen.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Modifying the slice elements<\/h2>\n\n\n\n<p>A slice is a reference to an underlying array. When you change an element in a slice, the corresponding element of the underlying array also changes. For example:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-7\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">package<\/span> main\n\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"fmt\"<\/span>\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">func<\/span> <span class=\"hljs-title\">main<\/span><span class=\"hljs-params\">()<\/span><\/span> {\n    guests := &#91;<span class=\"hljs-number\">3<\/span>] <span class=\"hljs-keyword\">string<\/span> {<span class=\"hljs-string\">\"Alice\"<\/span>, <span class=\"hljs-string\">\"Bob\"<\/span>, <span class=\"hljs-string\">\"John\"<\/span>}\n    vip := guests&#91;<span class=\"hljs-number\">0<\/span>:<span class=\"hljs-number\">2<\/span>]\n    vip&#91;<span class=\"hljs-number\">0<\/span>] = <span class=\"hljs-string\">\"Linda\"<\/span>\n    fmt.Println(guests)\n}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-7\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Output:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-8\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\">&#91;Linda Bob John]<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-8\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>In this example, we change the first element of the slice <code>vip<\/code> to Linda, the first element in the <code>guests<\/code> array also changes.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Length and capacity<\/h2>\n\n\n\n<p>Slices have two properties:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Length<\/strong> stores the number of elements in the slice.<\/li>\n\n\n\n<li><strong>Capacity<\/strong> is the number of elements in the underlying array from the index where you create the slice.<\/li>\n<\/ul>\n\n\n\n<p>For example:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-9\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">package<\/span> main\n\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"fmt\"<\/span>\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">func<\/span> <span class=\"hljs-title\">main<\/span><span class=\"hljs-params\">()<\/span><\/span> {\n    scores := &#91;]<span class=\"hljs-keyword\">int<\/span>{<span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span>, <span class=\"hljs-number\">3<\/span>, <span class=\"hljs-number\">4<\/span>, <span class=\"hljs-number\">5<\/span>, <span class=\"hljs-number\">6<\/span>, <span class=\"hljs-number\">7<\/span>, <span class=\"hljs-number\">8<\/span>, <span class=\"hljs-number\">9<\/span>, <span class=\"hljs-number\">10<\/span>}\n    avergeScores := scores&#91;<span class=\"hljs-number\">1<\/span>:<span class=\"hljs-number\">4<\/span>]\n    fmt.Println(<span class=\"hljs-string\">\"Length of slice:\"<\/span>,<span class=\"hljs-built_in\">len<\/span>(avergeScores))\n    fmt.Println(<span class=\"hljs-string\">\"Capacity of slice:\"<\/span>,<span class=\"hljs-built_in\">cap<\/span>(avergeScores))\n}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-9\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Output:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-10\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\">Length of slice: <span class=\"hljs-number\">3<\/span>\nCapacity of slice: <span class=\"hljs-number\">9<\/span><\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-10\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>In this example:<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>The <code>scores<\/code> array has 10 numbers from 1 to 10.<\/li>\n\n\n\n<li>The length of the <code>averageScores<\/code> slice is 3 because it includes elements from the index 1 to 3 (1, 2, and 3).<\/li>\n\n\n\n<li>The capacity of the <code>averageScores<\/code> slice is 9 because it contains elements from index 1 to the end of the array (2, 3, &#8230; 10).<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">Appending an element to a slice<\/h2>\n\n\n\n<p>To append an element to a slice, you use the built-in <code>append()<\/code> function. The <code>append()<\/code> function adds an element at the end of the slice and returns a new slice:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-11\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-keyword\">package<\/span> main\n\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"fmt\"<\/span>\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">func<\/span> <span class=\"hljs-title\">main<\/span><span class=\"hljs-params\">()<\/span><\/span> {\n\n    names := &#91;] <span class=\"hljs-keyword\">string<\/span> {}\n    names = <span class=\"hljs-built_in\">append<\/span>(names, <span class=\"hljs-string\">\"Alice\"<\/span>)\n    names = <span class=\"hljs-built_in\">append<\/span>(names, <span class=\"hljs-string\">\"Bob\"<\/span>)\n    names = <span class=\"hljs-built_in\">append<\/span>(names, <span class=\"hljs-string\">\"Joe\"<\/span>)\n\n    <span class=\"hljs-keyword\">for<\/span> index, name := <span class=\"hljs-keyword\">range<\/span> names {\n        fmt.Println(index, name)\n    }\n}<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-11\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Output:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-12\" data-shcb-language-name=\"Go\" data-shcb-language-slug=\"go\"><span><code class=\"hljs language-go\"><span class=\"hljs-number\">0<\/span> Alice\n<span class=\"hljs-number\">1<\/span> Bob\n<span class=\"hljs-number\">2<\/span> Joe<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-12\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Go<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">go<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<h2 class=\"wp-block-heading\">Summary<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li>A slice is a view into an underlying array and provides a more flexible interface.<\/li>\n\n\n\n<li>Use the <code>array[start:end]<\/code> syntax to create a slice from an array.<\/li>\n\n\n\n<li>Use the <code>len<\/code> function to get the number of elements in a slice.<\/li>\n\n\n\n<li>Use the <code>cap<\/code> function to get the capacity of a slice.<\/li>\n<\/ul>\n<div class=\"helpful-block-content\" data-title=\"\">\n\t<div class=\"wth-question\">Was this tutorial helpful?<\/div>\n\t<div class=\"wth-thumbs\">\n\t\t<button\n\t\t\tdata-post=\"201\"\n\t\t\tdata-post-url=\"https:\/\/www.gotutorial.org\/go-tutorial\/go-slice\/\"\n\t\t\tdata-post-title=\"Go Slice\"\n\t\t\tdata-response=\"1\"\n\t\t\tclass=\"wth-btn-rounded wth-yes-btn\"\n\t\t>\n\t\t\t<svg\n\t\t\t\txmlns=\"http:\/\/www.w3.org\/2000\/svg\"\n\t\t\t\tviewBox=\"0 0 24 24\"\n\t\t\t\tfill=\"none\"\n\t\t\t\tstroke=\"currentColor\"\n\t\t\t\tstroke-width=\"2\"\n\t\t\t\tstroke-linecap=\"round\"\n\t\t\t\tstroke-linejoin=\"round\"\n\t\t\t\tclass=\"feather feather-thumbs-up block w-full h-full\"\n\t\t\t>\n\t\t\t\t<path\n\t\t\t\t\td=\"M14 9V5a3 3 0 0 0-3-3l-4 9v11h11.28a2 2 0 0 0 2-1.7l1.38-9a2 2 0 0 0-2-2.3zM7 22H4a2 2 0 0 1-2-2v-7a2 2 0 0 1 2-2h3\"\n\t\t\t\t><\/path>\n\t\t\t<\/svg>\n\t\t\t<span class=\"sr-only\"> Yes <\/span>\n\t\t<\/button>\n\n\t\t<button\n\t\t\tdata-response=\"0\"\n\t\t\tdata-post=\"201\"\n\t\t\tdata-post-url=\"https:\/\/www.gotutorial.org\/go-tutorial\/go-slice\/\"\n\t\t\tdata-post-title=\"Go Slice\"\n\t\t\tclass=\"wth-btn-rounded wth-no-btn\"\n\t\t>\n\t\t\t<svg\n\t\t\t\txmlns=\"http:\/\/www.w3.org\/2000\/svg\"\n\t\t\t\tviewBox=\"0 0 24 24\"\n\t\t\t\tfill=\"none\"\n\t\t\t\tstroke=\"currentColor\"\n\t\t\t\tstroke-width=\"2\"\n\t\t\t\tstroke-linecap=\"round\"\n\t\t\t\tstroke-linejoin=\"round\"\n\t\t\t>\n\t\t\t\t<path\n\t\t\t\t\td=\"M10 15v4a3 3 0 0 0 3 3l4-9V2H5.72a2 2 0 0 0-2 1.7l-1.38 9a2 2 0 0 0 2 2.3zm7-13h2.67A2.31 2.31 0 0 1 22 4v7a2.31 2.31 0 0 1-2.33 2H17\"\n\t\t\t\t><\/path>\n\t\t\t<\/svg>\n\t\t\t<span class=\"sr-only\"> No <\/span>\n\t\t<\/button>\n\t<\/div>\n\n\t<div class=\"wth-form hidden\">\n\t\t<div class=\"wth-form-wrapper\">\n\t\t\t<div class=\"wth-title\"><\/div>\n\t\t\t<textarea class=\"wth-message\"><\/textarea>\n\t\t\t<input type=\"button\" name=\"wth-submit\" class=\"wth-btn wth-btn-submit\" id=\"wth-submit\" \/>\n\t\t\t<input type=\"button\" class=\"wth-btn wth-btn-cancel\" value=\"Cancel\" \/>\n\t\t<\/div>\n\t<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>In this tutorial, you&#8217;ll learn about the Go slice and how to use it effectively.<\/p>\n","protected":false},"author":1,"featured_media":0,"parent":10,"menu_order":19,"comment_status":"closed","ping_status":"closed","template":"","meta":{"footnotes":""},"class_list":["post-201","page","type-page","status-publish","hentry"],"_links":{"self":[{"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/pages\/201","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/comments?post=201"}],"version-history":[{"count":6,"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/pages\/201\/revisions"}],"predecessor-version":[{"id":420,"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/pages\/201\/revisions\/420"}],"up":[{"embeddable":true,"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/pages\/10"}],"wp:attachment":[{"href":"https:\/\/www.gotutorial.org\/wp-json\/wp\/v2\/media?parent=201"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}