gpt4 book ai didi

android - CMAKE_BUILD_TYPE 版本 : strange results

转载 作者:太空宇宙 更新时间:2023-11-04 12:59:27 32 4
gpt4 key购买 nike

我们正在创建一个 Android 应用程序来比较 ART 和 native 代码之间的执行时间。我们使用 Android Studio 和 CMake 编译 C/C++。

当我们在 CMakeList.txt 中设置标志时

set(CMAKE_BUILD_TYPE Release)

在一些算法(Primality Test 和 Fibonacci)中,对于所有不同的输入,执行时间急剧下降到 0ms。

这里是原生库

bool flag = false;

extern "C" JNIEXPORT void JNICALL Java_javacpp_cmr_com_sdkvsndk_MainActivity_cancel(JNIEnv *env, jobject obj) {
flag = true;
}


extern "C" JNIEXPORT jlong JNICALL Java_javacpp_cmr_com_sdkvsndk_MainActivity_primalityTest(JNIEnv *env, jobject obj, jlong r) {
if(r < 0) return -1L;
timeval start, stop;
long long t;
gettimeofday(&start, NULL);

bool prime = true;

unsigned long long sr = (unsigned long long) sqrt(r);
for (unsigned long long i = 2; (i < sr) && prime; i++) {
if (flag) return -1;
if (r % i == 0) prime = false;
}

gettimeofday(&stop, NULL);
t = (stop.tv_sec - start.tv_sec) * 1000;
t += (long long) ((stop.tv_usec - start.tv_usec) / 1000)
return (jlong) t;
}

flag 是一个标志,当我们终止执行算法的 asyncTask 时设置为真。

我不知道这是怎么可能的。有什么建议吗?谢谢。

最佳答案

这是因为默认情况下,您的 CMake 项目是使用 Debug 类型构建的。在这种类型中,会生成调试信息并禁用优化(-O0 -g 标志到 gcc)。

这是为了让您能够逐行执行您编写的 C++ 代码。如果您将类型更改为 Release,则会打开优化并且调试信息不​​包含在二进制文件中。

优化使代码运行得如此之快,无论您认为自己写的东西有多好,编译器仍然领先于您,并且会让它变得更好。然而,当代码被调试时,这些优化将显示不稳定的行为,行乱序执行,或根本不执行,变量不显示在 watch 中或显示错误,这不利于调试。

缺少调试信息意味着二进制文件更轻,但如果您需要调试它,最好练习一些汇编,因为有关 C++ 的哪一行导致这些汇编指令的任何信息都丢失了。作为旁注,还有 RelWithDebugInfo 构建类型,以防您确实需要调试优化代码。

通常 Android Studio 会为您处理合适的构建类型,因此您无需摆弄它。

关于android - CMAKE_BUILD_TYPE 版本 : strange results,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44902306/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com