int64_t 관련 해서 의아한 점이 있어 문의 드립니다.
글쓴이: bellfive2000 / 작성시간: 월, 2014/01/06 - 5:38오후
네트웍에서 패킷을 받아서 처리하는 중에..timestamp 계산을 해야 합니다.
관련해서
int64_t time1 = -1;
int64_t time2 = -1;
printf("getBufferedDurationUs => time1 (%lld), time2 (%lld)", time1, time2);
printf("getBufferedDurationUs => time2-time1 (%lld)", time2 - time2);
해서 봤을 때
getBufferedDurationUs => time1 (0), time2 (25824000)
getBufferedDurationUs => time2-time1 (0)
이렇게 처리되는데요.
진짜 0이 나오는 것인지 아니면 int64를 제대로 된 값으로 print를 못해서 이렇게 나오는지 궁금합니다.
time2-time1을 리턴받아서 처리해보면 0으로 인식하는 것 같긴 합니다.
if( 콜한 함수) A;
else B;
B루틴이 불리거든요..
int64_t 값 처리 문제가 좀 난해해서 문의 드립니다.
비슷한 케이스 없으셨는지요??
Forums:
64bit 정수형에 대한 출력 포맷은 표준에서는
64bit 정수형에 대한 출력 포맷은 표준에서는 PRId64 라는 매크로로 지정되어있습니다.
다음을 참고하세요. http://stackoverflow.com/questions/9225567/how-to-print-a-int64-t-type-in-c
그리고 코드를 올리실때는 정확한 코드를 올려주세요.
적당히 생략해서 올리면 더 문제를 난해하게 만듭니다.
올리신 코드는 절대로 말씀하신 내용을 출력할 수 없습니다.
(time2 - time2) 가 0 으로 계산되는게
(time2 - time2) 가 0 으로 계산되는게 그렇게 이상한가요 ?
제가 소스를 풀로 안올린 것은 알겠는데요.
그렇게 이상하니깐 올린 것 아닙니까?
a-b==0은 a==b라는 뜻이죠.
a-b==0은 a==b라는 뜻이죠.
잘못 올리고 지우는 법을 모르겠는데요..
time2 - time1입니다...ㅡ.ㅜ
에혀 제가 테스트 코드로 넣어서 나온 결과랑 다시 올리겠습니다.
일단 안드로이드로고요.
binary 형식으로
int main(int argc, char** argv)
{
int64_t time1 = 0;
int64_t time2 = 25824000;
printf("getBufferedDurationUs => time1 (%lld), time2 (%lld)\n", time1, time2);
printf("getBufferedDurationUs => time2-time1 (%lld)", time2 - time1);
return 0;
}
이렇게 했을 때 나온 결과가
chmod 777 test-int64
root@g2:/system/bin # ./test-int64
./test-int64
getBufferedDurationUs => time1 (0), time2 (25824000)
getBufferedDurationUs => time2-time1 (0)
이렇게 됩니다.
댓글 달기