global - Declare variables as global - MATLAB (original) (raw)

Main Content

Declare variables as global

Syntax

Description

Note

Global variables are inefficient and make errors difficult to diagnose. Use a function with input variables instead. For more information see Avoid Unnecessary Copies of Data.

global var1 ... varN declares the specified variables as global in scope.

Ordinarily, each MATLAB® function has its own local variables, which are separate from those of other functions and from those of the base workspace. However, if several functions all declare a particular variable name as global, then they all share a single copy of that variable. Any change of value to that variable, in any function, is visible to all the functions that declare it as global.

If the global variable does not exist the first time you issue the global statement, it is initialized to an empty 0x0 matrix.

If a variable with the same name as the global variable already exists in the current workspace, MATLAB issues a warning and changes the value of that variable and its scope to match the global variable.

example

Examples

collapse all

Create a function in your current working folder that sets the value of a global variable.

function setGlobalx(val) global x x = val;

Create a function in your current working folder that returns the value of a global variable. These two functions have separate function workspaces, but they both can access the global variable.

function r = getGlobalx global x r = x;

Set the value of the global variable, x, and obtain it from a different workspace.

setGlobalx(1138) r = getGlobalx

Assign a value to the global variable using the function that you defined in the previous example.

Display the value of the global variable, x. Even though the variable is global, it is not accessible at the command line.

Undefined function or variable 'x'.

Declare x as a global variable at the command line, and display its value.

Change the value of x and use the function that you defined in the previous example to return the global value from a different workspace.

Tips

Version History

Introduced before R2006a