


Analysis and explanation of common usage of const constants in C++
Let’s first explain const in C language and const in C. The variable modified by const in the former is not a real constant. It just tells the compiler that the variable cannot appear on the left side of the assignment symbol. The latter C evolves const based on C.
1. const
in C language:
const
modified variables are read-only and are still variables in nature.const
Modified local variables allocate space on the stackconst
Modified global variables Variables allocate space in the read-only storage areaconst
is only useful during compilation and is invalid during runtimeconst
Cannot define a real constant
const
The modified variable is not a real constant, it just tells the compiler that the variable cannot appear in The left side of the assignment symbol. const
Local variables allocate space on the stack, and the value in this space can be changed through a pointer. After the compilation period, the constant characteristics and read-only characteristics of const
variables are gone. The read-only characteristics are only valid during the compilation period and have no effect at runtime. Global variables modified by const
allocate space in the read-only storage area. Therefore, if a pointer is used to modify the global variable modified by const
, the program will crash because the read-only storage of the program has been modified. content in the area, most programs will crash.
2. const
in C:
C has evolved const
on the basis of C, as shown in:
const
When declaring, put the constant in the symbol tableDuring the compilation process, it is found that the constant is directly used in the symbol table Value replacement (constant folding)
During the compilation process, storage space may also be allocated for the corresponding constant:
-
const
Used globally or using thestatic
keyword description, stored in the read-only data areaextern const int i = 10; static const int i = 10; // 或者修饰全局变量 const int a =10; int main() {}
Copy after login to
const
in local variables The constant uses the&
operator to allocate space in the stack area
Note: Although the C compiler may allocateconst
constants space, but the value in its storage space will not be usedThe symbol table is a data structure generated during the compilation process
#include <iostream> #include <string> using namespace std; const int i = 10; // 如果通过指针去改变i,就会出现段错误:尝试修改只读数据区数据 int main() { const int a = 5; int *p = (int *)&a; // &a, 给a标识符分配空间了,并用p指向了该空间, // 可以通过*p访问这个地址,但是不能通过a来访问 *p = 10; // 不能通过指针去改变a的值 cout << a << endl; cout << *p << endl; return 0; }
3. Comparison with macro definition
C The const
constant in is similar to the macro definition
const int c = 5; // 类似于 #define c 5
but the difference between cosnt
and the macro definition is:
const
Constants are processed by the compilerThe compiler performs type checking and scope checking on
cosnt
constants-
Macro definitions are processed by the preprocessor, and only simple text replacement is performed
#include <stdio.h> void f() { #define a 3 const int b = 4; } void g() { printf("a = %d\n", a); // 在g函数中访问f函数中的宏定义,完全没有问题 // 在预处理的时候就进行了宏替换,对编译器来说,就是printf("a = %d\n", 3); // 宏是没有作用域的概念 // const 定义的常量,被编译器处理,是有作用域的,不能访问b printf("b = %d\n", b); } int main() { const int A = 1; const int B = 2; int array[A + B] = {0}; /* C编译 const修饰得到的只是具有只读特性的变量,数组的大小是由两个变量的大小决定的, 两个变量相加的结果需要在运行的时候才能直到,因此编译器编译的时候不知道这个数组长度,直接报错 */ /* C++编译 const是定义的真正意义上的常量,直接从符号表中取值,编译的时候就知道A和B的值, 可以得到数组的长度,不会报错 */ int i = 0; for(i=0; i<(A + B); i++) { printf("array[%d] = %d\n", i, array[i]); } f(); g(); return 0; }
Related articles:
const and define in php Difference analysis
Related videos:
PHP underlying analysis video tutorial
The above is the detailed content of Analysis and explanation of common usage of const constants in C++. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The steps to implement the strategy pattern in C++ are as follows: define the strategy interface and declare the methods that need to be executed. Create specific strategy classes, implement the interface respectively and provide different algorithms. Use a context class to hold a reference to a concrete strategy class and perform operations through it.

C++ template inheritance allows template-derived classes to reuse the code and functionality of the base class template, which is suitable for creating classes with the same core logic but different specific behaviors. The template inheritance syntax is: templateclassDerived:publicBase{}. Example: templateclassBase{};templateclassDerived:publicBase{};. Practical case: Created the derived class Derived, inherited the counting function of the base class Base, and added the printCount method to print the current count.

Causes and solutions for errors when using PECL to install extensions in Docker environment When using Docker environment, we often encounter some headaches...

In C, the char type is used in strings: 1. Store a single character; 2. Use an array to represent a string and end with a null terminator; 3. Operate through a string operation function; 4. Read or output a string from the keyboard.

In multi-threaded C++, exception handling is implemented through the std::promise and std::future mechanisms: use the promise object to record the exception in the thread that throws the exception. Use a future object to check for exceptions in the thread that receives the exception. Practical cases show how to use promises and futures to catch and handle exceptions in different threads.

Multithreading in the language can greatly improve program efficiency. There are four main ways to implement multithreading in C language: Create independent processes: Create multiple independently running processes, each process has its own memory space. Pseudo-multithreading: Create multiple execution streams in a process that share the same memory space and execute alternately. Multi-threaded library: Use multi-threaded libraries such as pthreads to create and manage threads, providing rich thread operation functions. Coroutine: A lightweight multi-threaded implementation that divides tasks into small subtasks and executes them in turn.

The calculation of C35 is essentially combinatorial mathematics, representing the number of combinations selected from 3 of 5 elements. The calculation formula is C53 = 5! / (3! * 2!), which can be directly calculated by loops to improve efficiency and avoid overflow. In addition, understanding the nature of combinations and mastering efficient calculation methods is crucial to solving many problems in the fields of probability statistics, cryptography, algorithm design, etc.

The release_semaphore function in C is used to release the obtained semaphore so that other threads or processes can access shared resources. It increases the semaphore count by 1, allowing the blocking thread to continue execution.
