Question 2: What is the concept of stack? Stack is an open space in memory for storing data.
Its expansion direction is from large address to small address of memory.
Used to store parameter passing when calling a function.
Static variables are stored in the static memory area of the program. At the back of the program, closest to the front.
Question 3: What is a stack and what is its function? Heaping is a common method of characterization in novels, which is usually used by small people. For example, a swordsman is very good and is known as invincible in the world. However, a little guy beat him by hook or by crook in a direct fight with him, showing his amazing strength. This is a stack of this little guy, in order to transform him into the prestige of this role through the great power of others. This is the stack
Question 4: What were the ancient buildings where things were stacked? The Book of Songs? Xiaoya has a saying, "Seeking thousands of warehouses", which shows that warehouse construction has a long history. Modern warehouses pay more attention to operating income than storage. This is the difference from the old warehouse. Therefore, modern warehouses attach importance to the rational layout of channels, the distribution of goods and the maximum height of accumulation from the aspects of transportation turnover, storage methods and building facilities, and allocate economical and effective mechanized and automated access facilities to improve storage capacity and work efficiency.
The warehouse consists of warehouses for storing articles and transportation facilities (such as cranes, elevators, slides, etc.). ), transportation pipes and equipment in and out of the warehouse, fire control facilities, management rooms, etc. According to the shape of the stored goods, warehouses can be divided into warehouses for storing solid goods, liquid goods, gas goods and powder goods; According to the nature of stored goods, it can be divided into warehouses for storing raw materials, semi-finished products and finished products; According to the architectural form, it can be divided into single-storey warehouse, multi-storey warehouse and cylindrical warehouse.
Single-storey warehouse is suitable for storing metal materials, building materials, ores, mechanical products, vehicles, oils, chemical raw materials, wood and its products. Single-storey buildings are often used in water transport terminal warehouses, railway transport warehouses and air transport warehouses to speed up loading and unloading. The general layout design of single-storey warehouse requires that roads should be connected, and loaded cars and forklifts can directly enter and leave the warehouse. This kind of warehouse generally adopts precast reinforced concrete structure, with a column grid of 6m and spans of 12m, 15m, 18m, 24m, 30m and 36m. A warehouse with a large ground load has a large span. The lifting capacity of the crane in the warehouse is determined according to the maximum weight of the stored goods. Single-beam crane or monorail crane can be used for lifting below 5 tons, and bridge crane can be used for lifting above 5 tons. The warehouse needs moisture protection. If it is used to store flammable materials, a flexible floor layer should be used to prevent sparks. The roof and walls should be watertight.
Multi-storey warehouses generally store department stores, electronic equipment, food, rubber products, medicines, medical devices, chemicals, stationery, instruments and meters, etc. There should be a loading and unloading site on the basement level, and loading and unloading vehicles can enter directly. The vertical transportation of goods generally adopts a freight elevator of 1.5 ~ 5 tons. It should be considered that the loading trolley or forklift can drive into the elevator room to speed up the loading and unloading. Slides are usually used to unload goods in multi-storey warehouses. The slideway is mostly reinforced concrete structure, and terrazzo waxing is the surface layer; Metal skeleton and steel plate surface layer can also be used, but steel plate should be prevented from rusting or stainless steel plate should be used as surface layer. If the unit load of a multi-storey warehouse is more than 500 kg, a flat floor can be used. Generally, warehouses are not painted, but spinal pulp can be white; Department stores, medicine, food and clothing shops should be painted to prevent insects from hiding in the cracks. The storage and transmission of "three-dimensional warehouse" in multi-storey warehouse is mechanized by using computer. This kind of warehouse occupies a small area and saves manpower, but the goods stored have a certain range.
Cylindrical silos generally store bulk cement, dry slag, fly ash, bulk grain, oil, gas and other gases. The architectural design of cylindrical warehouse is determined according to the type of goods stored and the way of loading and unloading. The top, wall and bottom of the reservoir must be waterproof and moisture-proof, and the top of the reservoir should have a dust suction device. In order to facilitate daily maintenance, it is necessary to set hanging holes, manholes (ladders are arranged on the warehouse wall), measuring holes and hooks. Cylindrical warehouse generally adopts cast-in-place prestressed reinforced concrete structure and adopts slip-form method for construction. Oil storage and gas storage are both metal structures. Attention should be paid to the ventilation of the warehouse, and shutters should be set on each outer wall of the warehouse, and metal nets should be added on the shutters to prevent birds from flying. Dangerous goods warehouses, such as warehouses storing oil (gas) or chemical raw materials, must be heat-proof and moisture-proof. The roof should be insulated or designed with explosion-proof roof, and the entrance and exit should be provided with fire zones. The ground should be made of materials that do not produce sparks, and asphalt ground can generally be used. Oil storage tanks shall be provided with oil storage pits. Food warehouses should be protected from ants and bees.
Question: What does stack mean? In the computer field, stack is a concept that cannot be ignored, but many people, even computer professionals, don't know that stack is actually two data structures.
Key points:
Heap: random order
Stack: FIFO
The difference between heap and stack
First, the preparatory knowledge-memory allocation of the program
The memory occupied by c/C++ compiled programs is divided into the following parts.
1, stack-automatically allocated and released by the compiler, storing parameter values of functions, values of local variables, etc. It works like a stack in a data structure.
2, heap (heap)-generally released by the programmer, if the programmer does not release, at the end of the program may be recycled by the OS. Note that the data structure is different from heap, and the allocation method is similar to linked list, hehe.
3. Global area (static area)-Global variables and static variables are stored together, initialized global variables and static variables are in one area, and uninitialized global variables and uninitialized static variables are in another adjacent area. -The system will be released after the program is completed.
4. Text constant area-this is where constant strings are placed. Released by the system after the program ends.
5. Program code area-stores the binary code of the function body.
Second, the sample program.
This is written by an elder, and it is written in great detail.
Main page
int a = 0; Global initialization area
char * p 1; Global uninitialized region
Master ()
{
int b; shed
char s[]= ABC; shed
Char * p2 shed
char * P3 = 123456; 123456\0 is in the constant area, and p3 is on the stack.
Static int c = 0;; Global (static) initialization area
p 1 =(char *)malloc( 10);
p2 =(char *)malloc(20);
10 and the allocation area of 20 bytes are in the heap area.
strcpy(p 1, 123456); 123456\0 is placed in the constant area, and the compiler may optimize it with 123456 pointed by p3.
}
Second, the theoretical knowledge of heap and stack
2. 1 application method
Stack:
Automatically assigned by the system. For example, declare a local variable int b; in a function; The system automatically creates a space for B in the stack.
Heap:
The programmer needs to apply for it himself and specify the size. Malloc function in c language.
Such as p1= (char *) malloc (10);
Using new operator in C++
For example, P2 = (char *) malloc (10);
But notice that p 1 and p2 are in the stack.
2.2
System response after application
Stack: As long as the remaining space of the stack is larger than the requested space, the system will provide memory for the program, otherwise an exception of stack overflow will be reported.
Heap: First of all, you should know that the operating system has a linked list of free memory addresses. When the system receives the application of the program,
The list will be traversed to find the first heap node whose space is larger than the application space, and then the node will be deleted from the list of idle nodes, and the space of this node will be allocated to the program. In addition, for most systems, the size of this allocation will be recorded in the first address of this memory space, so that the delete statement in the code can correctly release this memory space. In addition, because the size of the found heap node is not necessarily equal to the size of the application, the system will automatically put the redundant part back into the idle linked list.
2.3 Limitation of application scale
Stack: Under Windows, a stack is a data structure that extends to low-order addresses and contiguous memory areas. The address at the top of the stack and the maximum capacity of the stack are specified in advance by the system. Under WINDOWS, the stack size is 2M (some people say it is 1M, which is a constant determined at compile time). If the applied space exceeds the remaining space of the stack, an overflow will be prompted. Therefore, it can be downloaded from the stack ... >; & gt
Question 6: What is a stack? Stack is a data structure that executes LIFO algorithm.
Imagine a bamboo tube with a small diameter, with one end open and one end closed. There are several numbered balls, which are slightly smaller in diameter than bamboo tubes. Now put different numbers of balls into the bamboo tube, we can find a rule: the balls put in first can only be taken out later, on the contrary, the balls put in later can be taken out first So "first in and then out" is the characteristic of this structure.
Stack is such a data structure. It is to open a storage area in the memory, and the data is stored in this area one by one (that is, "push-push"). There is an address pointer that always points to the data unit where the last data pushed into the stack is located. The register that stores this address pointer is called the stack pointer. The unit where data is put at the beginning is called the "bottom of the stack". Data are stored one by one, and this process is called "stack pressing". During stack pushing, every time a piece of data is pushed into the stack, it is put into the next cell connected with the previous cell, and the address in the stack pointer is incremented by 1. When reading these data, read the data according to the address in the stack indicator, and the number of addresses in the stack indicator is automatically reduced by 1. This process is called "ejection". In this way, the principle of last in first out is realized.
Stack is the most commonly used data structure in computers. For example, the call of a function is realized through a stack in a computer.
Stacks can be stored in arrays or linked lists, which will be introduced later.
The following is the structure definition of the stack, including the top pointer of the stack and the array of data items. At first, the top pointer of the stack points to-1, and then when storing data, the top pointer of the stack increases 1, and after taking out data, the top pointer of the stack decreases 1.
#define MAX_SIZE 100
typedef int DATA _ TYPE
Structural stack
{
DATA_TYPE data [max _ size];
int top
};
Question 7: Briefly describe what a stack is. The process of entering and leaving the stack is actually two data structures. Stack is a data structure in which data items are arranged in order, and can only be at one end.
(called the top of the stack)
Insert and delete data items. Key points: heap, in any order. Last in, first out.
There are two basic operations in the data structure of stack: stack pressing and pop-up.
There are two symbols in the stack frame-the bottom of the stack and the top of the stack, where the top of the stack means push or pop.
The address of the data, and the bottom of the stack represents the memory address of the last data in the stack frame.
In Win32, register esp stores a pointer to the bottom of the stack, and the stack grows to a low address.
So esp points to the top element of the stack.
Stack comparison (operating system):
Compiler automatically allocates and releases, stores parameter values of functions, values of local variables, etc. that
The operation mode is similar to the stack in the data structure, and the first-level cache is used.
Usually it is in the storage space when it is called, and it will be released immediately after the call.
Heap (operating system):
Publishing is usually specified by programmers,
If the programmer does not release it, the program may eventually be recycled by the OS, and the distribution method is similar to a linked list.
The heap is stored in the second-level cache, and its life cycle is determined by the garbage collection algorithm of the virtual machine (not once it becomes an orphan). So the speed of calling these objects is relatively low.
Heap (data structure)
A heap can be regarded as a tree, such as heap sorting.
Stack (data structure)
: LIFO data structure
Different languages have different descriptions. You can check the api of each language.
Question 8: What is a stack? What does the stack do? Satisfied answer enthusiastic friends 20 1 1-06-22 stack is actually two concepts in data results and a way to store data. Stack: random order; Stack: LIFO. To be useful, when writing code, sometimes there must be a prescribed order for data access, and this order is your own. Then, according to the characteristics of the usefulness of the program you wrote, ask questions in the order of heap, stack or queue: Why should the stack pointer SP be re-assigned when programming? Answer: Isn't this initialization? Stack is a special storage area, its main function is to temporarily store data and addresses, and it is usually used to protect breakpoints and sites. Its characteristic is to access data according to the principle of first-in and then-out, where the entry and exit refer to the operation of entering and exiting the stack. Some units of 80C5 1 on-chip RAM can be used as stacks. There is an 8-bit stack pointer register SP and Dan to indicate which unit of on-chip RAM is at the top of the current stack. After the 80C5 1 single chip microcomputer system is reset, the initial value of SP is 07H, which means that information will accumulate from the 08H unit of internal RAM. However, the stack area of 80C5 1 series is not fixed, and the stack area can be changed by changing the value of SP register by software. In order to avoid the working register area and the bit addressing area, the initial value of SP can be set to an address value of 2FH or more. If the CPU uses two sets of working registers in its operation, if the bit variable is not used, the initial value of SP should be at least 0FH or more; If bit variables are used, the initial value of SP should be at least 2FH or more; KeilC5 1 compiler will automatically calculate the initial setting value of SP, without programmer's care.
Question: What does stack mean? In computer science, stack is a linear table, which only restricts insertion or deletion operations at the footer. Stack is a data structure and a special linear table, which can only be inserted at one end and deleted at the other. It stores data according to the principle of last in first out. The first data entered is pushed to the bottom of the stack, and the last data is at the top of the stack. When data needs to be read, it pops up from the top of the stack (the last data is read first). Stack is a special linear table that allows insertion and deletion at the same end. One end that allows insert and delete operations is called the top of the stack, and the other end is the bottom of the stack); Stacked; The bottom of the stack is fixed and the top of the stack is floating; When the number of elements in the stack is zero, it is called an empty stack. Insertion is generally called PUSH, and deletion is called POP. Stack is also called LIFO table. Stack can be used to store breakpoints in function calls, and stack can be used in recursion!
It has been made very clear above.
Although it is plagiarism.
Question 10: What are the characteristics of the stack? Stack is a data structure that executes LIFO algorithm.
Stack is such a data structure. It is to open a storage area in the memory, and the data is stored in this area one by one (that is, "push-push"). There is an address pointer that always points to the data unit where the last data pushed into the stack is located. The register that stores this address pointer is called the stack pointer. The unit where data is put at the beginning is called the "bottom of the stack". Data are stored one by one, and this process is called "stack pressing". During stack pushing, every time a piece of data is pushed into the stack, it is put into the next cell connected with the previous cell, and the address in the stack pointer is automatically incremented by 1. When reading these data, read the data according to the address in the stack indicator, and the number of addresses in the stack indicator is automatically reduced by 1. This process is called "ejection". In this way, the principle of last in first out is realized.