成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

性能優化小技巧-消除低效循環,讓你的程序快到飛起

開發 前端
由于編譯器的優化非常小心,它必須確保優化前后執行的效果是保持一致的,因此有些時候它會變得保守,并不能幫你優化太多。本文所需要的是在平常不需要花費太多力氣,養成習慣,并且對程序性能有好處的小技巧。

在分享這些性能優化技巧之前,需要說明以下幾點:

  • 不要過早優化性能
  • 現代編譯器的優化能力很強大
  • 80%的性能問題集中于20%的代碼中

但是由于編譯器的優化非常小心,它必須確保優化前后執行的效果是保持一致的,因此有些時候它會變得保守,并不能幫你優化太多。

本文所需要的是在平常不需要花費太多力氣,養成習慣,并且對程序性能有好處的小技巧。

[[322875]]

示例程序

為了說明本文所提到的技巧效果,先看一個示例程序,程序的目的非常簡單,就是將字符串中的小寫字母轉換為大寫),以下是完整可編譯運行代碼:

  1. #include<stdlib.h> 
  2. #include<stdio.h> 
  3. #include<time.h> 
  4. #include<ctype.h> 
  5. #include<string.h> 
  6. #include<sys/time.h> 
  7. #define MAX_LEN  1024*1024 
  8. void printCostTime(struct timeval *start,struct timeval *end) 
  9.     if(NULL == start || NULL == end) 
  10.     { 
  11.         return; 
  12.     } 
  13.     long cost = (end->tv_sec - start->tv_sec) * 1000 + (end->tv_usec - start->tv_usec)/1000; 
  14.     printf("cost time: %ld ms\n",cost); 
  15. int main(void) 
  16.     srand(time(NULL)); 
  17.  
  18.     int min = 'a'
  19.     int max = 'z'
  20.     char *str = malloc(MAX_LEN); 
  21.     //申請失敗則退出 
  22.     if(NULL == str) 
  23.     { 
  24.         printf("failed\n"); 
  25.         return -1; 
  26.     } 
  27.     unsigned int i = 0
  28.     while(i < MAX_LEN)//生成隨機數 
  29.     { 
  30.         str[i] = ( rand() % ( max - min ) ) + min; 
  31.         i++; 
  32.     } 
  33.     str[MAX_LEN - 1] = 0;  
  34.     //統計時間 
  35.     struct timeval start,end; 
  36.     gettimeofday(&start,NULL); 
  37.     for(i = 0;i < strlen(str) ;i++) 
  38.     { 
  39.         str[i]  = toupper( str[i] ); 
  40.     } 
  41.     gettimeofday(&end,NULL); 
  42.     printCostTime(&start,&end); 
  43.     free(str); 
  44.     str = NULL
  45.     return 0; 

隨機數的生成可參考《隨機數生成的方法》。我們主要關注下面的部分:

  1. for(i = 0;i < strlen(str) ;i++) 
  2.     str[i]  = toupper( str[i] ); 

很簡單,對不對?

運行看看時間:

  1. $ gcc - -o loop loop.c 
  2. $ ./loop 
  3. cost time: 42103 ms 

總共花了42秒多!(機器處理能力不同運行結果將會有較大差異)

消除低效循環

終于來到了我們的優化環節,我們觀察代碼其實很容易發現,每次循環的時候都會執行一次strlen計算字符串的長度,而這個計算具有以下特點

每次結果一致,屬于重復計算

strlen時間復雜度為O(N),也就是說,字符串越長,它需要的時間也就越多

一般情況下的使用是沒有太大問題的,但是問題在于,如果是在一個多次循環中,它能極大的影響效率。

到這里,優化方法想必你也清楚了,那就是將計算結果不會改變的計算移到循環外。代碼如下:

  1. unsigned int len = strlen(str); 
  2. for(i = 0;i < len ;i++) 
  3.     str[i]  = toupper( str[i] ); 

那么再次運行的結果如何呢?

  1. $ gcc -O0 -o loop loop.c 
  2. $ ./loop 
  3. cost time: 4 ms 

看到沒有,4ms,將近一萬的性能提升!而這個數值將會隨著字符串長度的增長進一步擴大。驚不驚喜,意不意外?

總結

實際上,本文的例子是比較極端的,然后實際中就可能隱藏著很多類似的代碼:

  • 在循環中計算,但是每次結果都一樣
  • 并且該計算的復雜度不是O(1)

對于這類代碼,在不絕對影響可讀性的情況下,完全可以將其移到循環外。

思考

如果是C++的string,循環時通過str.length()獲取長度,會如此影響性能嗎?為什么?

 

責任編輯:趙寧寧 來源: 編程珠璣
相關推薦

2024-06-12 12:28:23

2025-05-22 08:04:43

2020-11-18 13:54:27

IDEAJava開發

2021-01-04 15:11:57

開發 IDEA代碼

2020-05-06 16:32:18

for循環Python迭代

2024-11-27 09:46:34

2025-04-15 00:00:00

2023-03-01 23:59:23

Java開發

2024-06-21 08:21:44

2015-09-16 14:47:14

Android性能優化代碼

2020-09-29 07:54:05

Express 飛起

2011-04-13 10:51:58

MATLAB

2023-09-26 12:02:34

C++循環

2021-11-18 08:20:22

接口索引SQL

2019-07-18 12:40:49

Java編程語言性能優化

2025-04-09 00:01:05

2017-03-15 09:42:43

軟件開發云攜手

2022-02-21 13:27:11

接口性能優化索引命令

2024-01-08 17:09:07

Python解釋器CPython
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲午夜精品视频 | 久久久99国产精品免费 | 欧美亚洲日本 | 99精品久久久国产一区二区三 | 精精国产xxxx视频在线野外 | 四季久久免费一区二区三区四区 | www日韩欧美 | 99爱在线观看 | 久久99精品视频 | 午夜视频一区 | 日韩中文一区二区三区 | 国产乱码精品一区二区三区av | 狠狠色综合久久婷婷 | 国产精品久久在线 | 三级av在线 | 国产精品成人国产乱一区 | 综合二区 | 成人久草| 成av在线 | 福利视频一区 | 最近最新中文字幕 | 日本久久久影视 | 蜜桃视频在线观看免费视频网站www | 久久91精品国产 | 亚洲毛片 | 国产在线对白 | 国产日韩免费观看 | 国产精品欧美一区二区 | 天天躁日日躁狠狠躁2018小说 | 亚洲九九色 | 91影片 | 伊人免费视频二 | 午夜成人免费视频 | 欧美一级二级视频 | 国产高清久久久 | 情侣酒店偷拍一区二区在线播放 | 精品中文字幕在线 | 欧美精品一区二区三区在线 | 成年人在线观看 | 日韩在线一区二区三区 | 亚洲激情一区二区三区 |