
No.5ベストアンサー
- 回答日時:
Windows限定と言うか汎用的なx86系CPU限定で良いんでしょうか?
回答番号:No.3さんの回答に似てるんですが、
[命令キャッシュ]
(1)if文のelse/switch等の分岐を避ける。特に大きなコードを含んだ分岐で飛び越すのは避けた方がよい。
(2)処理の回数や時間が長い処理を出来るだけif文の条件が真になる時に通るようにする。
(3)関数やクラスの呼び出しを極力避ける。呼び出す場合は出来るだけ戻ってこない時間の掛かる処理にする。
[データキャッシュ]
(1)データは極力シーケンスにアクセスする。ランダムアクセスする場合も広範囲にアクセスしないように工夫する。
(2)データのアクセスとアクセスは出来るだけ間隔を空けて、レジスタ内で処理をするコードを心がける。
(3)スレッドなどCPUコア間で同期が必要な処理は避ける。データキャッシュのフラッシュが起こる可能性があるため。
上と合わせて、コンパイラ出力のアセンブラレベル命令コードを毎回確認して、無駄なコードが出ていないか確認する。
まぁ、今時のCPUでキャッシュばかり意識し過ぎるとプログラムの可読性が低いやら、結局処理が遅いとか、開発効率が悪すぎるとか、あまりメリットが無いかもしれません。
No.4
- 回答日時:
どのような理由で”キャッシュを意識"する必要があるのかわかりませんが,
一般論としては、あまり意味がないと考えています。
最適化オプションで"コードサイズを優先"にすれば、
かなりコンパクトになり、キャッシュに入る可能性も上がるのではないでしょうか?
本当にキャッシュを意識したいなら
まず、ターゲットのCPUを定めなくてはなりません。
同じIntel製のCPUでも
Pentium Dの場合
Core Aのキャッシュに入っているデータをコアBが直接アクセスできず
メモリを介した転送になるので、キャッシュのメリットを享受できません。
Core2Duoならば、キャッシュが共有されていますので
そんな心配は要りません。
このことは、マルチ・スレッドで初めて問題になることで
シングル・スレッドでは関係ないとも言えます。
ただ、CPUを意識しないと、キャッシュを活用したつもりでも
落とし穴にはまることがある一例として挙げさせていただきました。
キャッシュを意識する以前に効率化を検討する必要があると考えます。
こういった問題をわかりやすく取り上げた本として
"Effeective C++"
"more Effective C++"
を推薦します。
No.1
- 回答日時:
> 具体的にどうすればいいのか教えてほしいです。
具体的にどんなプログラムなのか、
具体的にどんな処理系(プラットフォームおよびコンパイラ)なのか、
具体的に現在どの程度の時間がかかっていて、どの程度高速化したいのか、
以上を補足してください。
この回答への補足
ごめんなさい。
どんなプログラムの場合の高速化なのかといったことは限定せず
広くキャッシュにヒットしやすい、キャッシュに適した、
高速なコードの書き方を求めています。
VisualC++で開発しています。
情報が少なく答えることができないのであればその場合は
ごめんなさい。返答ありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
win10で、正確な待ち時間の作り方
-
関数呼び出しの処理
-
処理速度向上のための小さな努力
-
VBA:CSVファイルの読出し手法...
-
逆コンパイルと逆アセンブルの...
-
Macターミナルで実行中のプログ...
-
powershell を使いカレントディ...
-
バックグラウンドのプロセスの...
-
マイコンからプログラムを読み...
-
sendkeysにてALT+CTRL+INSERTを...
-
スレッドにて同一メモリの書き...
-
エクセルVBA 大容量CSVファイル...
-
COBOLのS9タイプからXタイプへ...
-
libjpegで1bppBMPをjpegに変換...
-
WriteFile()でのデータ送信がで...
-
ソケットを用いた1対多通信につ...
-
openGLで物体を半透明にして表...
-
VB.NETでMessageBoxを表示した...
-
プロセスIDからウィンドウハ...
-
子プロセスの状態を親プロセス...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
win10で、正確な待ち時間の作り方
-
小数点を含む数値かどうか判断...
-
Excelでのセル内容の高速消去方法
-
If Not c Is Nothing Then ~延...
-
for文の処理に時間がかかってい...
-
Excel VBAにて、2GB超の点群デ...
-
VB 電卓 メモリー機能
-
絶対パスの取得について
-
DirectShowでのfilterの作り方
-
wavelet変換のソフト
-
エクセルVBA 時間抜けの取得
-
Excel(VBA)でSetTimer関数を使...
-
プログラム上のCPU稼働率低減に...
-
ノットイコールを教えて下さい
-
テキストファイルの空行をスキ...
-
.netからexcel操作の処理速度が...
-
SQLの速度をあげるには・・・
-
基本情報技術者試験詳しい方へ...
-
Excel VBA データ削除の高速化
-
VBA言語プログラミング
おすすめ情報