线程自动使用多个CPU核心



假设我的应用程序运行2个线程(例如一个渲染线程和一个游戏更新线程)。如果它运行在具有多核CPU的移动设备上(现在很常见),我能指望线程在可能的情况下自动分配给不同的核心吗?

我知道底层操作系统内核(安卓linux内核)决定了调度。我的问题是,我是否需要做任何额外的来启用多核使用,还是它是自动和透明的?

您需要做的是允许两个线程尽可能独立地运行。如果有两个线程总是在等待对方,那么它们可能会在同一个内核上运行以节省电力。(因为它可能看起来没有任何好处,必须使用核心)

情况如下:第一个线程解码位图,而渲染器将上一个位图的纹理上传到GPU。如果无所事事,第一个线程将进入睡眠状态;然后如果位图需要再次解码则唤醒。

我怀疑这是一个很好的例子,两个线程不会有帮助,因为解码位图应该比"上传"更快。这意味着你有两种情况

T1: decoding bit map, 
T2: waiting for a bit map.

T1: sleeping
T2: uploading a bit map.

T1: sleeping
T2: waiting for a bitmap.

你能看到为什么没有两个线程都需要运行(或者可能很少)的情况吗?这可能不会比只运行更快,甚至更慢

T1: decodes bitmap.
    uploads bitmap.
    waiting for a bitmap.