Как получить использование iOS CPU Core?

Много было одного и того же вопроса, но я не могу найти отличных ответов. Я посмотрел коды из этого конкретного поста, который дает мне использование на ядро, но оно неточное, всегда застревает на 14% или около того, даже когда Инструмент сообщает мне, что одно ядро ​​находится под полной нагрузкой (тест на первичность!).

Я также прочитал этот вопрос, от которого я фактически получил код.

У меня мало знаний о sysctlКажется, это ключ к подобным вещам. Может кто-нибудь объяснить мне, как я могу этого достичь, пример кода будет еще более ценным. Спасибо!

Это мой текущий код, он запускался в отдельном потоке, который я только что понял, может быть проблемой, кто-нибудь может подтвердить? (Я использую NSThread и NSNotificationCenter для отправки информации об использовании в основной поток.)

- (void)updateCPUUsage
{
    NSMutableArray* arrayOfCPUUsage = [NSMutableArray array];
    while ( 1 )
    {
        processor_info_array_t _cpuInfo, _prevCPUInfo = nil;
        mach_msg_type_number_t _numCPUInfo, _numPrevCPUInfo = 0;
        unsigned _numCPUs;
        NSLock *_cpuUsageLock;

        int _mib[2U] = { CTL_HW, HW_NCPU };
        size_t _sizeOfNumCPUs = sizeof(_numCPUs);
        int _status = sysctl(_mib, 2U, &_numCPUs, &_sizeOfNumCPUs, NULL, 0U);
        if(_status)
            _numCPUs = 1;

        _cpuUsageLock = [[NSLock alloc] init];

        natural_t _numCPUsU = 0U;
        kern_return_t err = host_processor_info(mach_host_self(), PROCESSOR_CPU_LOAD_INFO, &_numCPUsU, &_cpuInfo, &_numCPUInfo);
        if(err == KERN_SUCCESS) {
            [_cpuUsageLock lock];
            for(unsigned i = 0U; i < _numCPUs; ++i) {
                Float32 _inUse, _total;
                if(_prevCPUInfo) {
                    _inUse = (
                              (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER]   - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER])
                              + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM])
                              + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE]   - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE])
                              );
                    _total = _inUse + (_cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE] - _prevCPUInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE]);
                } else {
                    _inUse = _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_USER] + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_SYSTEM] + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_NICE];
                    _total = _inUse + _cpuInfo[(CPU_STATE_MAX * i) + CPU_STATE_IDLE];
                }
                [arrayOfCPUUsage addObject:@(_inUse / _total)];
            }

            [_cpuUsageLock unlock];

            if(_prevCPUInfo) {
                size_t prevCpuInfoSize = sizeof(integer_t) * _numPrevCPUInfo;
                vm_deallocate(mach_task_self(), (vm_address_t)_prevCPUInfo, prevCpuInfoSize);
            }

            _prevCPUInfo = _cpuInfo;
            _numPrevCPUInfo = _numCPUInfo;

            _cpuInfo = nil;
            _numCPUInfo = 0U;
        }
        [[NSNotificationCenter defaultCenter] postNotification:[NSNotification notificationWithName:@"CPUUsageUpdate" object:[arrayOfCPUUsage copy]]];
        [arrayOfCPUUsage removeAllObjects];
        usleep(1000);
    }
}

0 ответов

Другие вопросы по тегам