回答編集履歴
4
コード修正
test
CHANGED
@@ -38,7 +38,7 @@
|
|
38
38
|
|
39
39
|
struct timespec start, current;
|
40
40
|
|
41
|
-
i
|
41
|
+
time_t diff = 0;
|
42
42
|
|
43
43
|
clock_gettime(CLOCK_MONOTONIC, &start);
|
44
44
|
|
3
誤字修正
test
CHANGED
@@ -4,15 +4,13 @@
|
|
4
4
|
|
5
5
|
|
6
6
|
|
7
|
-
計測を開始した時点での`clock_gettime()`の値と、現在の`clock_gettime()`の値の**差が10秒以下の間処理を繰り返す**プログラムを書けば、HIG4TOさんのやりたいことが実現できるのではないでしょうか。
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
7
|
+
`clock_gettime()`は`timespec`型の値を返し、`timespec`型は秒とナノ秒の情報が入った構造体です。
|
12
8
|
|
13
9
|
`clock_gettime(CLOCK_MONOTONIC, ×pec型の変数)`とすると単調増加の値が得られます。
|
14
10
|
|
15
11
|
計測を始めた時点の値と現在の値の**差が10秒以下の間処理を繰り返す**プログラムを書けばHIG4TOさんのやりたいことが実現できるのではないでしょうか。
|
12
|
+
|
13
|
+
|
16
14
|
|
17
15
|
今回はナノ秒のオーダーは必要ないと思われますので、単純に秒のみを比較します。
|
18
16
|
|
2
参考文献を追加
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をつかったコードに変更
test
CHANGED
@@ -1,16 +1,24 @@
|
|
1
|
+
【追記】
|
2
|
+
|
1
|
-
`gettime
|
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
|
11
|
+
なお、`clock_gettime()`は`timespec`型の値を返し、`timespec`型は秒とナノ秒の情報が入った構造体です。
|
12
|
+
|
13
|
+
`clock_gettime(CLOCK_MONOTONIC, ×pec型の変数)`とすると単調増加の値が得られます。
|
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
|
37
|
+
struct timespec start, current;
|
30
38
|
|
39
|
+
int diff = 0;
|
31
40
|
|
32
|
-
|
33
|
-
diff = (time_t)0;
|
34
|
-
|
35
|
-
|
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, ¤t);
|
56
|
+
|
49
|
-
diff =
|
57
|
+
diff = current.tv_sec - start.tv_sec;
|
50
58
|
|
51
59
|
}
|
52
60
|
|