lists.html 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <html>
  2. <head>
  3. <meta charset="utf-8">
  4. <meta name="viewport" content="width=device-width, initial-scale=1">
  5. <title>Gravity: List</title>
  6. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css" />
  7. <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
  8. <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:400,700,800">
  9. <link rel="stylesheet" href="scripts/highlight/styles/github-gist.css">
  10. <link rel="stylesheet" href="stylesheets/styles.css">
  11. </head>
  12. <body>
  13. <!-- BEGIN NAVIGATION BAR -->
  14. <nav class="navbar navbar-default navbar-fixed-top">
  15. <div class="container">
  16. <div class="navbar-header">
  17. <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
  18. <span class="sr-only">Toggle navigation</span>
  19. <span class="icon-bar"></span>
  20. <span class="icon-bar"></span>
  21. <span class="icon-bar"></span>
  22. </button>
  23. <a class="navbar-brand" href="http://gravity-lang.org"><img src="images/logo.png" width="32px" height="36px"></a>
  24. </div>
  25. <div id="navbar" class="navbar-collapse collapse">
  26. <ul class="nav navbar-nav navbar-right">
  27. <li class="active"><a href="index.html">Gravity</a></li>
  28. <li><a href="internals/index.html">Internals</a></li>
  29. <li><a href="https://github.com/marcobambini/gravity">GitHub</a></li>
  30. </ul>
  31. </div><!--/.nav-collapse -->
  32. </div>
  33. </nav>
  34. <!-- END NAVIGATION BAR -->
  35. <div class="container body-container">
  36. <div class="main-content">
  37. <div class="row">
  38. <!-- BEGIN SIDEBAR -->
  39. <div class="col-sm-3 border-right section-left">
  40. <div saveheight="1" class="sidebar-nav">
  41. <h4>INTRODUCTION</h4>
  42. <ul>
  43. <li><a href="index.html"><span>Introduction</span></a></li>
  44. <li><a href="getting-started.html"><span>Getting Started</span></a></li>
  45. </ul>
  46. <h4>LANGUAGE GUIDE</h4>
  47. <ul>
  48. <li><a href="syntax.html"><span>Syntax</span></a></li>
  49. <li><a href="operators.html"><span>Operators</span></a></li>
  50. <li><a href="types.html"><span>Types</span></a></li>
  51. <li><a href="lists.html" class="active"><span>Lists</span></a></li>
  52. <li><a href="maps.html"><span>Maps</span></a></li>
  53. <li><a href="enum.html"><span>Enum</span></a></li>
  54. <li><a href="functions.html"><span>Functions</span></a></li>
  55. <li><a href="closures.html"><span>Closures</span></a></li>
  56. <li><a href="classes.html"><span>Classes</span></a></li>
  57. <li><a href="control-flow.html"><span>Control Flow</span></a></li>
  58. <li><a href="loops.html"><span>Loops</span></a></li>
  59. <li><a href="fibers.html"><span>Fibers</span></a></li>
  60. </ul>
  61. <h4>ADVANCED</h4>
  62. <ul>
  63. <li><a href="api.html"><span>Embedding API</span></a></li>
  64. <li><a href="system.html"><span>System class</span></a></li>
  65. <li><a href="unit-test.html"><span>Unit test</span></a></li>
  66. <li><a href="contributing.html"><span>Contributing</span></a></li>
  67. </ul>
  68. </div>
  69. </div>
  70. <!-- END SIDEBAR -->
  71. <div class="col-sm-9 border-left section-right">
  72. <h1 class="section-header">List</h1><hr>
  73. <p class="section-content">
  74. Lists (or arrays) are simple sequence of objects, their size is dynamic and their index starts always from 0. They provide fast random access to their elements. You can create a list by placing a sequence of comma-separated expressions inside square brackets:
  75. </p>
  76. <pre><code class="swift">
  77. var r = [1, 2, "Hello", 3.1415, true];
  78. // list has a count property
  79. var n = r.count; // n is 5
  80. </code></pre>
  81. <h4 class="section-h4">Accessing elements</h4>
  82. <p>You can access an element from a list by calling the subscript operator [] on it with the index of the element you want. Like most languages, indices start at zero:
  83. </p>
  84. <pre><code class="swift">
  85. var names = ["Mark", "Andrew", "Paul", "Ross", "Frank", "Max"];
  86. names[0]; // "Mark"
  87. names[2]; // "Paul"
  88. </code></pre>
  89. <p>Negative indices counts backwards from the end:</p>
  90. <pre><code class="swift">
  91. var names = ["Mark", "Andrew", "Paul", "Ross", "Frank", "Max"];
  92. names[-1]; // "Max"
  93. names[-2]; // "Frank"
  94. </code></pre>
  95. <h4 class="section-h4">Iterating elements</h4>
  96. <p>The subscript operator works well for finding values when you know the key you’re looking for, but sometimes you want to see everything that’s in the list. Since the List class implements the iterator method, you can easily use it in a for loop:</p>
  97. <pre><code class="swift">
  98. var people = ["Mark", "Andrew", "Paul", "Ross", "Frank", "Max"];
  99. for (var name in people) {
  100. System.print("Current name is " + name);
  101. }
  102. </code></pre>
  103. <h4 class="section-h4">Adding elements</h4>
  104. <p>A List instance can be expanded by setting an index that is greater than the current size of the list:</p>
  105. <pre><code class="swift">
  106. var list = [10,20,30,40,50];
  107. list[30] = 22; // list contains now 31 elements (index 0...30)
  108. </code></pre>
  109. <h4 class="section-h4">List as a stack</h4>
  110. <p>The List class implements the push/pop methods as a convenient way to treat a list as a stack:</p>
  111. <pre><code class="swift">
  112. var list = [10,20,30,40,50];
  113. list.push(100); // add 100 to the list
  114. var v1 = list.pop(); // pop 100
  115. var v2 = list.pop(); // pop 50
  116. </code></pre>
  117. <h4 class="section-h4">List Contains</h4>
  118. <p>The List class implements the contains methods as a convenient way to check for the existance of a value in a list:</p>
  119. <pre><code class="swift">
  120. var list = [1, 2, "Hello", 3.1415, true];
  121. return list.contains(3.1415); // Returns: true
  122. </code></pre>
  123. <h4 class="section-h4">List Joins</h4>
  124. <p>The List class implements the join method as a convenient way to
  125. interpret a list as a string:</p>
  126. <pre><code class="swift">
  127. var list = [1,2,3,4,5];
  128. list.join(" + "); // Becomes: "1 + 2 + 3 + 4 + 5"
  129. </code></pre>
  130. </div> <!-- /row -->
  131. </div> <!-- /main-content -->
  132. </div> <!-- /container -->
  133. <!-- BEGIN FOOTER -->
  134. <footer class="navbar-fixed-bottom">
  135. <div class="container footer">
  136. <p>
  137. </p>
  138. </div>
  139. </footer>
  140. <!-- END FOOTER -->
  141. <!-- Bootstrap JS -->
  142. <script src="https://code.jquery.com/jquery-1.12.4.min.js"></script>
  143. <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
  144. <!-- Highlights JS -->
  145. <script src="scripts/highlight/highlight.min.js"></script>
  146. <script>hljs.initHighlightingOnLoad();</script>
  147. </body>
  148. </html>