TimerによるCPU使用率の増加

ActiveBasicでのプログラミングでわからないこと、困ったことなどがあったら、ここで質問してみましょう(質問を行う場合は、過去ログやWeb上であらかじめ問題を整理するようにしましょう☆)。
返信する
メッセージ
作成者
shinshin

TimerによるCPU使用率の増加

#1 投稿記事 by shinshin »

active basic初心者です。
Timer関数を利用して下記のようなカウンタ表示を作ったのですが、しばらくするとメモリの使用量とCPU使用率が上昇して、カウンタ表示のカウントアップのタイミングが遅くなってしまいます。
Timerを使用してもCPU使用率が上がらなくきちんと定期的にカウントアップしてくれる方法をどなたか教えてください。

コード: 全て選択


Sub MainWnd_CommandButton1_Click()
    SetTimer(hMainWnd, 0, 10, 0)
End Sub

Sub MainWnd_Timer(TimerID As DWord)    
    i = i + 1  
    SetWindowText(GetDlgItem(hMainWnd, EditBox1), Str$(i))
End Sub
7
記事: 473
登録日時: 2005年5月31日(火) 18:51
お住まい: 新潟県
連絡する:

Re: TimerによるCPU使用率の増加

#2 投稿記事 by 7 »

> Timerを使用してもCPU使用率が上がらなくきちんと定期的にカウントアップしてくれる方法をどなたか教えてください。
SetTimer()関数を使ってもCPU使用率が上がらない方法は分かりませんが、SetTimer()関数を使わないで済ませる方法を考えました。
コマンドボタン1を押すとスタート、もう一回押すとエンドです。
コード自体問題ありそうですし、ソフトウェアを終了する時もスレッドがどうなってるかとか把握しなきゃですし、初心者の方には向かないんですけどね...。
※終了時、スレッドがどうなってるか調べる部分は書いておりませんです
ゲスト

#3 投稿記事 by ゲスト »

よくわかりませんが、10mSecごとにテキストを書き換えると処理が間に合わずにイベントキューが溜まって行き、メモリが不足してスワップしだすのでCPU負荷が増して行くのでは無いでしょうか?

タイマーイベント10回中に1回SetWindowTextを行う等の軽量化を行うしかないと思います。
konisi
記事: 893
登録日時: 2005年7月25日(月) 13:27
お住まい: 埼玉県東松山市
連絡する:

#4 投稿記事 by konisi »

この場合、Str$にも問題があると思います。

コード: 全て選択

Sub MainWnd_Timer(TimerID As DWord)
    Dim buf[255] As Byte
    i = i + 1  
    wsprintf(buf,"%d",i)
    SetWindowText(GetDlgItem(hMainWnd, EditBox1), buf)
End Sub
#ところでプログラミング質問板のトピック数が丁度1000になるところを見れて少し嬉しかったりします。
Website→http://web1.nazca.co.jp/himajinn13sei/top.html
ここ以外の場所では「暇人13世」というHNを主として使用。

に署名を書き換えて欲しいと言われたので暇だしやってみるテスト。
shinshin

#5 投稿記事 by shinshin »

みなさんありがとうございました。

Str$を使わない方法を試したら、メモリ使用量もあがらず安定してカウントしてくれました。
しかし、なんでStr$が問題かわかりません。また、教えていただいたプログラムに関しても細かく教えていただきたいのですが。。。。。
よろしくお願いいたします。
MML
記事: 154
登録日時: 2006年5月02日(火) 16:27

#6 投稿記事 by MML »

横から、すいません。

> Str$を使わない方法を試したら、メモリ使用量もあがらず安定してカウントしてくれました。
> しかし、なんでStr$が問題かわかりません。また、教えていただいたプログラムに関しても細かく教えていただきたいのですが。。。。。
> よろしくお願いいたします。
Str$ってけっこう動作が重いんですよ。
そのため、CPU使用量が上がっているのではないかと。
konisi
記事: 893
登録日時: 2005年7月25日(月) 13:27
お住まい: 埼玉県東松山市
連絡する:

#7 投稿記事 by konisi »

メモリの使用量に関しては、String型周りでメモリリークが発生しているためだと思われます。
詳しく調べてませんが。

少なくともこの場合はStr$(i)の戻り値を一度ローカル変数に格納し、StrPtrで変換して渡したほうがいいように見えます。

wsprintf関数は、ざっと調べたところ
http://winofsql.jp/VA003334/cmaterial040601205757.htm
に具体例が、
http://www2.ocn.ne.jp/~cbmaho/homepage/ ... printf.htm
に詳しい解説が載ってます。
Website→http://web1.nazca.co.jp/himajinn13sei/top.html
ここ以外の場所では「暇人13世」というHNを主として使用。

に署名を書き換えて欲しいと言われたので暇だしやってみるテスト。
shinshin

#8 投稿記事 by shinshin »

みなさんありがとうございました!!
返信する