Javatpoint Logo
Javatpoint Logo

How to Access a Local Variable from a Different Function in C++

Addressing local variable retrieval of different functions in C++ is important and is the heart of the program's variable scope, function call, and data sharing. In C++, local variables can be declared only within a specific block of code, usually in the body of a particular function, narrowing their scope to that block.

Moreover, the cases sometimes occur when getting the value of the local variable from another function is done. Such requirements could be, for example, for passing data between functions, doing operations, or exchanging info among different parts of the program.

Pass by Reference: It is done by sending the local variable as a reference parameter to another function, thereby making the function able to modify the variable directly.

Return the Value: In this manner, the function that contains the local variable is returned its value and will then be grasped by the calling function.

Static Local Variables: A predefined local static variable keeps its value across many function calls by allowing the data to be shared between the function calls.

Global Variables: But not recommended for several reasons, including the problems of encapsulation and maintainability, declaring a variable as global allows access to it from any function within the program.

Each approach's implications concern code structure, data encapsulation, and program design. The choice of the suitable method needs to be studied attentively to consider the kinds of behaviour desired, the degree of links to data, and the general structure of the program. Moreover, observing the best practice policies of eliminating global variables and adopting encapsulation and information hiding is paramount in sustaining code quality and readability.

Pass by Reference:

The function passes a value of a local variable by the reference, not by the value. It provides a function with direct access to the variable's memory location. As a result, the function can modify the original variable right away. Here's a detailed explanation:

Program:

Output:

Original value of localVar: 10
Modified value of localVar: 20

Explanation:

  • Declaration of Function:

There is a function termed 'modifyValue' with one argument. This parameter is denoted by using ampersand (&). It is a statement that denotes a reference parameter. Within the modifyValue function, we alter the parameter's value directly. As the parameter is referenced, whatever happens inside the function will modify the original variable passed into it.

  • Main Function:

We declare a local variable, localVar, and then assign the value of 10 to it. Next, we put out the value of the local variable. This modifies the function as we refer to the localVar as an argument. This passes the variable by reference to the function. We now reassign localVar to the appropriate value.

  • Output:

After executing the program, the Output will print the old value of localVar and the new value of localVar.

In the end, this code displays the principle of passing a local variable by reference to a function. By applying the pass-by-reference principle to the variable, the changes made to it inside the function change the value declared in the main function without producing a new copy.

Complexity Analysis:

Pass by Reference:

The function passes a value of a local variable by the reference, not by the value. It provides a function with direct access to the variable's memory location. As a result, the function can modify the original variable right away. Here's a detailed explanation:

In C++, you indicate that you are getting a reference to the variable and not its value by adding the '&' symbol before the variable name in the function parameter declaration.

Time Complexity:

The time complexity of the code is straightforward since it contains only simple operations and no loop or recursive calls.

The running time of this algorithm is O(1), which implies that it is invariant to the input size and all other parameters.

Space Complexity:

The space complexity of the code mainly depends on the memory utilization by the variables and any extra overhead from the function calls.

In the main function, a single integer variable localVar is declared, which always consumes the same amount of memory independent of the input size. Thus, it has O(1) space complexity.

Within the modifyValue function, no new variables are created. The only memory usage is the reference parameter localVar, which again requires a constant amount of memory.

On the whole, the space complexity of the code is O(1), which means constant space utilization regardless of input size or other factors.

Return the Value:

Changing the value of a local variable in one function and using it in another is achieved by implementing a function, including the code, to compute or modify the value of a local variable and then return it to the calling function.

Program:

Output:

Returned value from computeValue function: 10

Explanation:

  • Function Declaration and Definition (computeValue):

We call a function computeValue that returns an integer value as Output. Within the function, we declare a local variable, localVar, with a value of 10. Next, we redirect the value to localVar using a return statement.

  • Main Function:

In the main function, we call the computeValue function. We assigned the returned value to a result string. Also, we produce the value from the computer function as our Output.

When the instance method computeValue is called from main as a static function, it computes the value of the local variable localVar and returns it. This computed result is then set as a value of the result variable in the main function; thus, the value is available for use in the main function or anywhere else in the other function.

This approach permits sending information directly from one function to another without requiring formal parameters to pass shared data as function arguments, making the code modular and more understandable. On the other hand, it should be added that copies of the local variable's value are created, which might affect a function's speedwork if the data type is large.

Complexity Analysis:

Time Complexity:

The time complexity of the code is defined by actions performed in the functions. Here, as well, only the variable initialization and return statement are included, and they are the ones that execute in constant time. Constant time is not affected by the input size or any other factors.

Similarly, the main function contains simple operations: call the computeValue function, which gives and wears the return value. These procedures run within a constant amount of time.

Thus, the big O notation of the Code is O(1), which means that there would be a constant time complexity irrespective of the size of the input or any other factors or complications.

Space Complexity:

The code's memory is determined by the size of the variables present and the size of soft capacities.

By defining a single integer variable, local art, which takes a fixed amount of memory no matter the input panel size, the computeValue function, demand is approximately constant. However, with a constant amount of space complexity O(1), it provides the same result.

In the main function, more memory is allocated for storage of the returned value (result) and any variables that may be called as an overhead to such function calls. Nonetheless, these memory-hungry variables' read and write operations involve O(1) space complexity.

In general, the code is complex throughout the space O(1); constant space usage is not dependent on the input size and any factor in use.

Static Local Variables:

A variable designated as static inside a function in C++ keeps its value between function calls; thus, it retains its value between function calls. These arrays use fewer resources on memory to execute, and the same memory address holds a reference to array objects. Conversely, regular local variables are created and initialized during each function call but have a different memory address.

Program:

Output:

Function called 1 times
Function called 2 times
Function called 3 times

Explanation:

  • Function Definition (myFunction):

Inside function myFunction, a variable count is declared inner and local and initialized to 0. As the words suggest, it is a variable that persists with its value between function calls. Every time myFunction is used, count, being an array element, is incremented in value with 1. There is a function that prints how many times it has been called.

  • Main Function:

The mediator function main function has three consecutive calls of myFunction, each one of them. However, when myFunction is called, the counter variable increases and this number reflects it for the times that myFunction has been called.

  • Output:

When the program displays the Output, it includes messages, each representing the number of times that myFunction function has been called. Because the count static variable stores its value after function calls, the Output prints the counts obtained for each consecutive function call to myFunction.

Finally, the highlighted function myFunction operation includes the usage of the static local variable count within. This step is achieved using this variable, which conserves its value between function calls, thus helping the function implement the state across multiple executions. With every call to function, the count gets incremented, thus giving out an outcome that shows how many times the function has been used.

Complexity Analysis:

Time Complexity:

The time complexity of the code depends on the internal calculus operations inside the myFunction and main function.

Inside the myFunction function, the operations that occur circa the static variable count complete during constant time. The output operation (std::cout ), however, takes constant time. By invoking myFunction once and three times, one after another, three executions of the features above inside myFunction are made.

Hence, the number of function calls is the section of time complexity O (1). The complete program is placed on O (1) * 3 = O (3), which can be reduced to O (1).

Space Complexity:

The space complexity of the code can be defined through the usage of variables by memory and the need for overhead of every function call.

In the definition of the myFunction function, we define a static (thus, relatively "big" size) local variable called count, which takes up the space in the memory irrespective of the input size or the number of function calls. Thus, the complexity of this algorithm is O(1).

In the main function, there is no statement where the additional variable must be declared, except the temporary variable on which you can make the function call overhead, which makes the space complexity constant.

The memory space of the code is constant, so the space requirement does not depend on the input size, or the number of function calls required.







Youtube For Videos Join Our Youtube Channel: Join Now

Feedback


Help Others, Please Share

facebook twitter pinterest

Learn Latest Tutorials


Preparation


Trending Technologies


B.Tech / MCA