Table of Contents
C++ Performance Analysis (3): Heap Object vs. Stack (auto) Object, heapstack
It is generally believed that the performance improvement is the 90 ~ 10 rule, that is, 10% Your code is responsible for 90% of performance problems. Programmers who have done large-scale software projects generally know this concept.
figure14.13.gif
Home Backend Development PHP Tutorial C++ performance analysis (3): Heap Object vs. Stack (auto) Object, heapstack_PHP tutorial

C++ performance analysis (3): Heap Object vs. Stack (auto) Object, heapstack_PHP tutorial

Jul 13, 2016 am 10:20 AM
heap

C++ Performance Analysis (3): Heap Object vs. Stack (auto) Object, heapstack

It is generally believed that the performance improvement is the 90 ~ 10 rule, that is, 10% Your code is responsible for 90% of performance problems. Programmers who have done large-scale software projects generally know this concept.

However, for software engineers, some performance problems are unforgivable. Whether they belong to 10% or 90%, they "must" be improved. Here I will talk about one of the issues: whether to use heap or stack.

Java, C#, and JavaScript programmers generally don't care whether the objects they create are in the heap or the stack, because for these languages, objects can only "live" in the heap. This is undoubtedly much simpler for programmers. But for C++ programmers, you can choose three places to create objects:

  • Data section of the program
  • Working Stack
  • Heap

Where should Object live? This problem must be determined by the properties of the application. Sometimes there is no choice. For example, for dynamically generated global variables, there is no other way but to live in the heap.

However, once we have a choice, such as a temporary object as a carrier of complex data, the answer is clear: stack should be preferred. For example, the following simple example:

    // heap vs stack test

double HeapVsStack(bool heap, int loop, int &result)

{

if (heap)

               {

clock_t begin = clock();

for(int i = 0; i < loop; ++i)

                                                                

intPair *p = new intPair(1,2); <🎜>

                                                                                   delete p;              } clock_t end = clock();

return double(end - begin) / CLOCKS_PER_SEC;          } else

                {

clock_t begin = clock();

for(int i = 0; i < loop; ++i)

                                                                

intPair p = intPair(1,2);

result += p.ip1 + p.ip2;

             } clock_t end = clock();

return double(end - begin) / CLOCKS_PER_SEC;

         }

}

The bold enlarged part of the program is the "application logic" to be measured. An intPair is created in the heap above and deleted after use. Below, define the same auto variable in the stack. There is no need to care after use.

Make the following simple test calls to this program:

int result = 0;

printf("Heap time: %f n", HeapVsStack(true, 100000, result));

printf("Stack time: %f n", HeapVsStack(false, 100000, result));

I had to call 100,000 times because the difference in their time-consuming is too big: the use case of stack shows 0ms for less than 10,000 times.

The test results show that the heap took 300ms and the stack took 5ms, a difference of 60 times.

Conclusion:

1) If application logic allows, use stack-based auto variables and never use heap variables.

2) If you need to use a lot of heap, it is recommended to use std::vector as your own simple heap manager. Avoid using heap directly and extensively to create ad-hoc objects.

3) Some classes used for temporary calculations may be prohibited from being generated in the heap. See http://stackoverflow.com/questions/1941517/explicitly-disallow-heap-allocation-in-c article.

Heap memory

What is the difference between them and Stack memory? Quote: www.blogjava.net/...9.aspxI was reading an article this morning that dealt with the problem of buffer overflow. When it came to the stack and heap of C, I didn’t understand something, so I searched Baidu and found the forum. The explanations on the above are relatively messy. After searching on Google, I found that there are many explanations in the Lecture Notes of foreign universities. Here are three simple excerpts, one is in C, the second is for Java, and the third is from the perspective of OS.

Stack vs Heap AllocationHow the memory of the computer is organized for a running program? When a program is loaded into memory, it is organized into three areas of memory, called segments: the text segment, stack segment, and heap segment. The text segment (sometimes also called the code segment) is where the compiled code of the program itself resides. This is the machine language representation of the program steps to be carried out, including all functions making up the program, both user defined and system.
The remaining two areas of system memory is where storage may be allocated by the compiler for data storage. The stack is where memory is allocated for automatic variables within functions. A stack is a Last In First Out (LIFO) storage device where new storage is allocated and deallocated at only one ``end'', called the Top of the stack. This can be seen in Figure 14.13.

figure14.13.gif

When a program begins executing in the function main(), space is allocated on the stack for all variables declared within main(), as seen in Figure 14.13(a). If main() calls a function, func1 (), additional storage is allocated for the variables in func1() at the top of the stack as...The rest of the text>>


What is the difference between Heap memory and Stack memory?





The heap is dynamically allocated, such as malloc or new, while the stack is static.

And the location of the applied storage space is different.

http://www.bkjia.com/PHPjc/868462.html
www.bkjia.com
true


http: //www.bkjia.com/PHPjc/868462.html

TechArticle

C++ Performance Analysis (3): Heap Object vs. Stack (auto) Object, heapstack It is generally believed that the performance improvement is The 90 ~ 10 rule means that 10% of the code is responsible for 90% of the performance problems. Did...

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Working with Flash Session Data in Laravel Working with Flash Session Data in Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

Build a React App With a Laravel Back End: Part 2, React Build a React App With a Laravel Back End: Part 2, React Mar 04, 2025 am 09:33 AM

This is the second and final part of the series on building a React application with a Laravel back-end. In the first part of the series, we created a RESTful API using Laravel for a basic product-listing application. In this tutorial, we will be dev

Simplified HTTP Response Mocking in Laravel Tests Simplified HTTP Response Mocking in Laravel Tests Mar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Notifications in Laravel Notifications in Laravel Mar 04, 2025 am 09:22 AM

In this article, we're going to explore the notification system in the Laravel web framework. The notification system in Laravel allows you to send notifications to users over different channels. Today, we'll discuss how you can send notifications ov

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP Logging: Best Practices for PHP Log Analysis PHP Logging: Best Practices for PHP Log Analysis Mar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

See all articles