VisualStudio2008の最適化について
こんにちは。
質問させてください。
現在VisualStudioでとある処理を書きました。
わかりやすく以下のコードを書いたとします。
#include <stdio.h>
#include <windows.h>
#pragma comment ( lib, "winmm" )
int main()
{
DWORD t = timeGetTime();
int sum=0;
int i=0;
for( i=0;i<0x7fffffff;++i )
++sum;
t = timeGetTime() - t;
printf( "time -> %d\n", t );
return 0;
}
今回は単純にfor文の時間を計測したいとします。
上記コードをReleaseモード実行速度重視 (/O2)でコンパイルし、実行すると出力は必ず
time -> 0
と出力されます。
上記コードをReleaseモード実行速度重視 (/O2)でコンパイルしアセンブリとして出力したものです。
CONSTSEGMENT
??_C@_0M@DAGCMHCE@time?5?9?$DO?5?$CFd?6?$AA@ DB 'time -> %d', 0aH, 00H ; `string'
push esi
mov esi, DWORD PTR __imp__timeGetTime@0
push edi
call esi
mov edi, eax
call esi
sub eax, edi
push eax
push OFFSET ??_C@_0M@DAGCMHCE@time?5?9?$DO?5?$CFd?6?$AA@
call DWORD PTR __imp__printf
add esp, 8
pop edi
xor eax, eax
pop esi
ret 0
アセンブリコードを見るとするとint sumはコード中でインクリメントされるだけで他に使用されないので、最適化によって削除されてしまっているようです。
この、時間を計測したいところだけ適度に最適化させつつ、処理が残るようにするような命令はありませんでしょうか?
pragmaでかこったりするだけで処理が消されない程度に最適化されるとうれしいのですが・・・
よろしくお願いします。
/*
VisualaStudio 2008 academic Edition
今回のテストケースではsumの値もコンソールに出力すれば最適化で消されずに済むのですが最適化の計算によってforループは削除され、代わりに即値(0x7fffffff)がそのまま表示されるように最適化されてしまいます。
ですので今回は
・使用した変数を使用するように書き換える
・最適化で消されないようにコードを記述しなおす
・inlineアセンブラで最適化させない
といった解決策以外でよろしくお願いします。
*/
No.1ベストアンサー
- 回答日時:
optimize プラグマ
http://msdn.microsoft.com/ja-jp/library/xz7ttk5s …
ただ、CPU自体の実行時の動作最適化はどうしようもないので、CPU型番毎の動作は異なるものと思われます。あとクロックがターボブーストする可能性もありますよ。
それに昔のPentimumと今のiCoreでは同じCPUクロックでも結果の実行クロック数は全く違いますから。
検証自体にどのぐらいの意味があるか疑問です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 malloc関数を使ってください!お願いします! 最 1 2022/07/21 09:28
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分 1 2022/07/19 17:03
- C言語・C++・C# プログラミング実行後の表示される値を答えよ #include<stdio.h> void main( 7 2022/05/20 00:07
- C言語・C++・C# 至急お願いします。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分母 3 2022/07/19 17:09
- C言語・C++・C# スタックフレームの消滅 6 2023/05/20 12:33
- C言語・C++・C# Cのオブジェクトファイルの逆アセンブル 5 2023/05/13 01:51
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VB.netの重複データ数カウント...
-
エクセル VBA タイマー動作 の...
-
デザイン時のVisible=Falseは実...
-
1つのVBAコードをすべてのコア...
-
初心者です。gulpでコンパイル...
-
リクエスト結果が一瞬しか表示...
-
以下のコードを実行しても、オ...
-
onload onunload onbeforeunloa...
-
PowerPointで時計表示
-
VBAで時間による処理判定
-
jquery の書き始めについて
-
C# showdialogの戻り値について
-
JSPの処理の途中で、JavaScript...
-
alert()が実行できない
-
C#でボタン名を変更しても動く
-
WSH をC#で作ることは可能でし...
-
同一ページに複数の異なるJAVA...
-
Visual Basic 6.0 のテキストボ...
-
JavaScriptで時間のカウントを...
-
プルダウンリストを作りMySQLか...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
JSPの処理の途中で、JavaScript...
-
if(1){...}とはどういうことで...
-
PowerPointで時計表示
-
C#でボタン名を変更しても動く
-
デザイン時のVisible=Falseは実...
-
初心者です。gulpでコンパイル...
-
jQuery ui Datepicker 明日以降...
-
VBA SORT Applyでエラー
-
〔Excel:VBA〕マクロの実行が異...
-
innerHTMLなどの反映タイミング
-
リクエスト結果が一瞬しか表示...
-
1つのVBAコードをすべてのコア...
-
VBA ステータスバー DoEvents
-
VB.netでタイマーがスタートし...
-
javascriptで最初のところに戻...
-
Excelのマクロ一括実行ができな...
-
既存のwebサイトで、ローカルの...
-
JavaScriptでショートカットキ...
-
ラベルの色がかわってくれない
-
eval()の危険性の具体例を教え...
おすすめ情報