c++ - 为什么 Mac 上的 SDL 比 Linux 慢得多?
问题描述
我正在开发一个使用 SDL2 呈现的单线程图形程序。见最后一个更小的例子。
它既可以在旧的 Linux 机器上运行,也可以在稍旧的 Mac 上运行。Linux 计算机的处理器为 1.60GHz,而 Mac 的处理器为 2.2GHz。Linux 上的 SDL 版本是 2.0.8,而 Mac 上的 SDL 版本是 2.0.10。在两台计算机上,我clang++
使用优化标志-O3
和-flto
. 我调用了可执行文件./intergrid -fullscreen -pixel-size 3
(本质上,我让程序绘制了很多像素。)
出于某种原因,较慢的 Linux 计算机毫不费力地执行程序,而 Mac 需要几秒钟来渲染第一帧。-no-draw
正如预期的那样,当我使用该标志禁用图形时,Mac 比 Linux 机器快。
编辑:Linux 计算机具有用于图形的“Intel Haswell Mobile”,Mac 列出“Intel Iris Pro 1536 MB”。
这是一个最小的可重现示例:
#include <SDL2/SDL.h>
#include <stdio.h>
int main(void)
{
SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER);
SDL_Window *window = SDL_CreateWindow(
"Example",
SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED,
0, 0,
SDL_WINDOW_SHOWN);
SDL_SetWindowFullscreen(window, SDL_WINDOW_FULLSCREEN_DESKTOP);
SDL_Renderer *renderer = SDL_CreateRenderer(window, -1, 0);
SDL_Rect viewport;
SDL_RenderGetViewport(renderer, &viewport);
// The screen is not rendered to unless this is done:
SDL_Event event;
while (SDL_PollEvent(&event))
;
Uint32 ticks_before = SDL_GetTicks();
for (int x = 0; x < viewport.w - 10; x += 10) {
for (int y = 0; y < viewport.h - 10; y += 10) {
// I just chose a random visual effect for this example.
SDL_Rect square;
square.x = x;
square.y = y;
square.w = 10;
square.h = 10;
SDL_SetRenderDrawColor(renderer, x % 256, y % 256, 255, 255);
SDL_RenderFillRect(renderer, &square);
}
}
Uint32 ticks_after = SDL_GetTicks();
printf("Ticks taken to render: %u\n", ticks_after - ticks_before);
SDL_RenderPresent(renderer);
SDL_Delay(500);
// I Won't worry about cleaning stuff up.
}
我在 Mac 和 Linux 上用clang++ -O3 -flto <filename> -lSDL2
. 当我在 Mac 上运行程序时,它打印:
Ticks taken to render: 849
Linux 上的程序打印:
Ticks taken to render: 4
这是一个巨大的差异!
解决方案
@keltar 找到了一个对我来说足够好的解决方案,但他们尚未将其发布为答案,所以我会的。由于某种原因,SDL2 的 Metal 后端非常慢,因此解决方案是使用 OpenGL 后端。SDL_SetHint(SDL_HINT_RENDER_DRIVER, "opengl")
如果我发现默认驱动程序是 Metal(使用SDL_GetRendererInfo
.) ,我通过调用来完成此操作
推荐阅读
- load - 在 Docker 环境中安装 netdata 时经常出现高 cpu 负载
- ios - 选择 Image 或 Take Photo 并转到新的 ViewController
- javascript - 2 $http 获取函数
- scala - 根据 Spark Scala 中的列条件获取最新信息不起作用
- php - 如何在 PHP 中创建对象?
- r - 具有非完整网格的 Surfaceplot
- c# - DataTip 不在 cshtml 文件中显示值
- c# - 将屏幕截图附加到测试步骤结果 (ITestStepResult) - VSTS
- yocto - Yocto 2.4.2 未能做_package_qa 任务
- postgresql - 使用新名称克隆 postgres 数据库