Pregunta

Aquí está mi método C para obtener el pid del proceso Finder. GetProcessInformation () está causando una violación de segmento. ¿Por qué?

Aquí está la función:

static OSStatus
GetFinderPID(pid_t *pid)
{
    ProcessSerialNumber psn = {kNoProcess, kNoProcess};
    ProcessInfoRec info;
    OSStatus status = noErr;

    info.processInfoLength = sizeof(ProcessInfoRec);
    info.processName = nil;

    while (!status)
    {
        status = GetNextProcess(&psn);
        if (!status)
        {
            status = GetProcessInformation(&psn, &info);
        }
        if (!status &&
            info.processType == 'FNDR' &&
            info.processSignature == 'MACS')
        {
            return GetProcessPID(&psn, pid);
        }
    }

    return status;
}

Aquí está la traza inversa:

Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_INVALID_ADDRESS at address: 0x0000000032aaaba7
0x00007fffffe00623 in __bzero ()
(gdb) bt
#0  0x00007fffffe00623 in __bzero ()
#1  0x00007fff833adaed in CreateFSRef ()
#2  0x00007fff833ab53b in FSPathMakeRefInternal ()
#3  0x00007fff852fc32d in _CFGetFSRefFromURL ()
#4  0x00007fff852fbfe0 in CFURLGetFSRef ()
#5  0x00007fff85dd273f in GetProcessInformation ()
#6  0x0000000100000bef in GetFinderPID [inlined] () at /path/to/main.c:21
¿Fue útil?

Solución

poniendo a cero la estructura ProcessInfoRect trabajó, en lugar de tratar de determinar qué campos individuales deben ser puestos a cero.

Otros consejos

Es necesario configurar processAppSpec a cero si no quiere que se volvió, de lo contrario tendrá un puntero no válido allí.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top