質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

解決済

【C言語】clock()の挙動

shuta_202141
shuta_202141

総合スコア43

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

3回答

0評価

0クリップ

289閲覧

投稿2022/01/08 03:53

困っていること

clock() / CLOCKS_PER_SECでCPUの経過時間を計測したいのですが、clock()の挙動がうまく把握できません。clock() / CLOCKS_PER_SECでCPU経過時間の秒数を計測できるはずですが、ストップウォッチで測る時間と大きくことなります。

2番目の該当コードの場合はうまくいくのですが一番目の該当コードの場合うまく機能しません。その理由がなんなのかが知りたいです。

該当のソースコード

1

#include <stdio.h> #include <time.h> int main(void) { int i; clock_t cpu_time; double sec; /* 負荷を掛ける処理(適当です) */ for (i = 0; i < 1000000; i++) { printf("\r計測中..."); } /* CPU時間をチェック */ cpu_time = clock(); /* 秒に直す */ sec = (double)cpu_time / CLOCKS_PER_SEC; printf("%f秒\n", sec); return 0; }

2

#include <stdio.h> #include <time.h> #include <stdlib.h> #define MAX_STAGE 10 int sleep(unsigned long x) { clock_t c1 = clock(), c2; do { if ((c2 = clock()) == (clock_t)-1) //エラー検出 { return 0; } } while (1000.0 * (c2 - c1) / CLOCKS_PER_SEC < x); return 1; } int main(void) { sleep(1000); printf("1秒後"); return 0; }

実行結果

1

//ストップウォッチで計測した場合2~3秒程度でした 計測中...0.263727秒

2

//1秒後に表示される 1秒後

###OS
MacOS Monterey ver12.1です

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

shuta_202141

2022/01/08 04:01

「あくまでCPU時間のため、精度がミリ秒まであるとまでは言えませんが、手元のストップウォッチと計測を比べるとほぼ一致していました。」記載されているのですが、10倍違う結果になってしまいます。
dodox86

2022/01/08 09:05

なぜ挙動が違うも何も、提示の1と2は完全に別モノのコードですが、、

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。