因为算法测试做了一答应微秒的代码。但是在lua调用C++的时候出现了一些问题:
下面是代码:
luatil.h
#pragma once
class lautil {
//返回当前的微秒;
static long long getCurMicroTime();
};
lautil.cpp
#include "lautil.h"
#include "cocos2d.h"
#include <windows.h>
#include <sys/timeb.h>
#include <time.h>
#if !defined(_WINSOCK2API_) && !defined(_WINSOCKAPI_)
struct timeval
{
long tv_sec;
long tv_usec;
};
#endif
static int gettimeofday(struct timeval* tv)
{
union {
long long ns100;
FILETIME ft;
} now;
GetSystemTimeAsFileTime(&now.ft);
tv->tv_usec = (long)((now.ns100 / 10LL) % 1000000LL);
tv->tv_sec = (long)((now.ns100 - 116444736000000000LL) / 10000000LL);
return (0);
}
long long lautil::getCurMicroTime()
{
#ifdef CC_TARGET_PLATFORM == CC_PLATFORM_WIN32
timeval tv;
gettimeofday(&tv);
return ((time_t)tv.tv_sec*(time_t)1000000 + tv.tv_usec);
#endif
return 0;
}
1.第一个bug:写头文件的时候刚开始没有声明public,一直默认private··,结果使用genbendings生成出来的auto文件一直没有getCurMicroTime()这个函数!
2.代码已经没有错了,但是编译的时候说getCurMicroTime() 这个函数没有实现,找不到。但是两个文件已经放入了Class文件夹下。 结果原因是没有导入到VS项目当中,所以VS不会去编译Cpp文件。即使你手动放入到了Class文件夹下。
这样就可以在LUA中输出以微秒为单位的数值。