回答編集履歴

4

コード修正

2021/10/26 03:06

投稿

fj68
fj68

スコア752

test CHANGED
@@ -38,7 +38,7 @@
38
38
 
39
39
  struct timespec start, current;
40
40
 
41
- int diff = 0;
41
+ time_t diff = 0;
42
42
 
43
43
  clock_gettime(CLOCK_MONOTONIC, &start);
44
44
 

3

誤字修正

2021/10/26 03:05

投稿

fj68
fj68

スコア752

test CHANGED
@@ -4,15 +4,13 @@
4
4
 
5
5
 
6
6
 
7
- 計測を開始した時点での`clock_gettime()`の値と、現在の`clock_gettime()`の値の**差が10秒以下の間処理を繰り返す**プログラムを書けば、HIG4TOさんのやりたいことが実現できるのではないでしょうか。
8
-
9
-
10
-
11
- なお、`clock_gettime()`は`timespec`型の値を返し、`timespec`型は秒とナノ秒の情報が入った構造体です。
7
+ `clock_gettime()`は`timespec`型の値を返し、`timespec`型は秒とナノ秒の情報が入った構造体です。
12
8
 
13
9
  `clock_gettime(CLOCK_MONOTONIC, &timespec型の変数)`とすると単調増加の値が得られます。
14
10
 
15
11
  計測を始めた時点の値と現在の値の**差が10秒以下の間処理を繰り返す**プログラムを書けばHIG4TOさんのやりたいことが実現できるのではないでしょうか。
12
+
13
+
16
14
 
17
15
  今回はナノ秒のオーダーは必要ないと思われますので、単純に秒のみを比較します。
18
16
 

2

参考文献を追加

2021/10/26 03:02

投稿

fj68
fj68

スコア752

test CHANGED
@@ -21,6 +21,10 @@
21
21
 
22
22
 
23
23
  HIG4TOさんの環境が不明ですのでここでは`unistd.h`の`usleep()`を使っていますが、Windowsなどの場合は代替となる関数(`windows.h`の`Sleep()`とか)をググってみてください。
24
+
25
+
26
+
27
+ [時間情報の取得 clock_gettime() - 時間の扱い - 碧色工房](https://www.mm2d.net/main/prog/c/time-05.html)
24
28
 
25
29
 
26
30
 

1

clock_gettimeをつかったコードに変更

2021/10/26 03:01

投稿

fj68
fj68

スコア752

test CHANGED
@@ -1,16 +1,24 @@
1
+ 【追記】
2
+
1
- `gettime`というのが何の関数なのか不明ですが、考え方は共通する部分もあると思いますので、C標準の`time()`を使った一例を紹介しま
3
+ `clock_gettime()`を使ったコードに変更しました
2
4
 
3
5
 
4
6
 
5
- `time()`は「西暦 1970 年1月1日からの経過秒数」を返す関数です。
6
-
7
- 計測を開始した時点での`time()`の値と、現在の`time()`の値の**差が10秒以下の間処理を繰り返す**プログラムを書けば、HIG4TOさんのやりたいことが実現できるのではないでしょうか。
7
+ 計測を開始した時点での`clock_gettime()`の値と、現在の`clock_gettime()`の値の**差が10秒以下の間処理を繰り返す**プログラムを書けば、HIG4TOさんのやりたいことが実現できるのではないでしょうか。
8
8
 
9
9
 
10
10
 
11
- なお、`time()`は`time_t`型の値を返し、`difftime()`で2つの`time_t`型の値の差を得ることができます。
11
+ なお、`clock_gettime()`は`timespec`型の値を返し、`timespec`型は秒とナノ秒情報入った構造体です。
12
+
13
+ `clock_gettime(CLOCK_MONOTONIC, &timespec型の変数)`とすると単調増加の値が得られます。
14
+
15
+ 計測を始めた時点の値と現在の値の**差が10秒以下の間処理を繰り返す**プログラムを書けばHIG4TOさんのやりたいことが実現できるのではないでしょうか。
16
+
17
+ 今回はナノ秒のオーダーは必要ないと思われますので、単純に秒のみを比較します。
12
18
 
13
19
  処理を繰り返すときは定期的に`sleep()`のような関数を呼び出さないとハングアップしてしまいますので注意です。
20
+
21
+
14
22
 
15
23
  HIG4TOさんの環境が不明ですのでここでは`unistd.h`の`usleep()`を使っていますが、Windowsなどの場合は代替となる関数(`windows.h`の`Sleep()`とか)をググってみてください。
16
24
 
@@ -26,13 +34,11 @@
26
34
 
27
35
  int main() {
28
36
 
29
- time_t diff, start;
37
+ struct timespec start, current;
30
38
 
39
+ int diff = 0;
31
40
 
32
-
33
- diff = (time_t)0;
34
-
35
- start = time(NULL);
41
+ clock_gettime(CLOCK_MONOTONIC, &start);
36
42
 
37
43
 
38
44
 
@@ -46,7 +52,9 @@
46
52
 
47
53
 
48
54
 
55
+ clock_gettime(CLOCK_MONOTONIC, &current);
56
+
49
- diff = difftime(time(NULL), start);
57
+ diff = current.tv_sec - start.tv_sec;
50
58
 
51
59
  }
52
60