1. Place a command button on your worksheet and add the following code lines:
data:image/s3,"s3://crabby-images/3b24e/3b24eb76e5d4c303b4e401687051782fb226a863" alt=""
2. Result when you click the command button on the sheet:
data:image/s3,"s3://crabby-images/753c0/753c0b99af1c182e9d07dec25eec806bf1a2553d" alt=""
3. Result when you click another time:
data:image/s3,"s3://crabby-images/10155/10155b7eb11ff8771935ee7eb6465b57df1e8a09" alt=""
Explanation: Excel VBA destroys the variable when the procedure ends. Each time you click the command button on the sheet, Excel VBA creates the variable x again, adds the value 1 to it, and displays the result.
4. Now replace the keyword Dim with the keyword Static.
data:image/s3,"s3://crabby-images/b44fc/b44fce2927878e23b63358843fdabba4a4c32a33" alt=""
5. Result when you click the command button on the sheet:
data:image/s3,"s3://crabby-images/37cbb/37cbb194427838dcb77796683c7899f93c1d52a6" alt=""
6. Result when you click another time:
data:image/s3,"s3://crabby-images/f2d3c/f2d3c8671507bbc50d7aa3b4b0643843f26fc836" alt=""
Conclusion: static variables retain their values, even when a procedure ends.
Note: static variables will be destroyed when you click the Reset (Stop) button or when you close your workbook..