Difference between revisions of "Category:LSL Types"

From Second Life Wiki
Jump to navigation Jump to search
m
Line 9: Line 9:
<lsl>integer myVar = 123;</lsl>
<lsl>integer myVar = 123;</lsl>


== Mutability ==
== Pass-by-value ==
All types in [[LSL]] are immutable (they can't be mutated by side effect), [[LSL Variables|variables]] can only be changed by being overwritten.
[[LSL]] as a language uses pass-by-value for all types{{Footnote|The VMs that run compiled scripts however do use reference types and pass-by-reference, they just ensure copies are made.}}. When a value (it can be the value in a variable) is passed as a parameter to a function, that function is provided with it's own unique copy of the value. So if in the course of executing the function, it modifies the parameter, that modification only changes the functions copy of the value, it does not effect or change the original (or other copies).
 
*[[:Category:LSL Functions|Built in functions]] will never modify the variables used as parameters.
*[[:Category:LSL Functions|Built in functions]] will never modify the variables used as parameters.
*User functions that change the values of parameters inside the function scope will not have those changes applied to the variables that supplied those parameters.
*User functions that change the values of parameters inside the function scope will not have those changes applied to the variables that supplied those parameters.
The VMs that run compiled LSL preserve this despite using reference types for several of the types.

Revision as of 11:33, 27 April 2012

Introduction

A data type is a definition of the type or format of data.

An integer for example, defines that the variable which will hold this kind (or 'type') of data shall contain only integers, which for 32-bit are whole number values in the range of 0x00000000 to 0xFFFFFFFF.

Example

<lsl>integer myVar = 123;</lsl>

Pass-by-value

LSL as a language uses pass-by-value for all types[1]. When a value (it can be the value in a variable) is passed as a parameter to a function, that function is provided with it's own unique copy of the value. So if in the course of executing the function, it modifies the parameter, that modification only changes the functions copy of the value, it does not effect or change the original (or other copies).

  • Built in functions will never modify the variables used as parameters.
  • User functions that change the values of parameters inside the function scope will not have those changes applied to the variables that supplied those parameters.

The VMs that run compiled LSL preserve this despite using reference types for several of the types.

Subcategories

This category has the following 8 subcategories, out of 8 total.

Pages in category "LSL Types"

The following 7 pages are in this category, out of 7 total.