0

每次我调用方法'pthread_create'时,编译代码后运行它,总是导致错误'Segmentation fault',我的代码如下所示,任何人都可以帮助我,非常感谢!

int iLogThreadID;
pthread_t dwLogThread;
iLogThreadID = pthread_create(&dwLogThread, NULL, &logInformation, NULL);

方法“logInformation”如下所示

void* logInformation(void * info)
{
    char logInfoString[SINGLE_LOG_SIZE];
    memset(logInfoString,0,SINGLE_LOG_SIZE);
    if(gLogFile == NULL)
    {
        return EXEC_ERROR;
    }
    while(g_logThreadStatus == LOG_THREAD_RUNNING)
    {
        if(g_logBufferStartIndex == g_logBufferEndIndex)
        {
            sleep(10 );
            continue;
        }
        if(popLogBuffer(logInfoString) == EXEC_ERROR)
            continue;
        fputs(logInfoString, gLogFile);
        memset(logInfoString,0,SINGLE_LOG_SIZE);
    }
    g_logThreadStatus = LOG_THREAD_TERMINATED;
    return EXEC_OK;
}

生成文件

CXX= /usr/bin/gcc
LIBDIR=../coapLib
CFLAGS= -I${LIBDIR}
CXXFLAGS= ${CFLAGS} -g
LIBS= -lm -pthread -nostartfiles
OBJ = coapClient.o Block.o CoapMsg.o CoapObserve.o CoapOpt.o Common.o Config.o    IfMatch.o IO.o link.o md5.o cHashtable.o cJSON.o Log.o MsgHandle.o Network.o URIdatabase.o    messagePrint.o ConMsgBase.o ClientMsgHandle.o ClientInterpreter.o 
coapClient: ${OBJ}
    ${CXX} $(CXXFLAGS) -o coapClient ${OBJ} ${LIBS}
coapClient.o: coapClient.c
        ${CXX} ${CXXFLAGS} -c coapClient.c
...
clean:
rm -f *.o coapClient
4

2 回答 2

3

一个可能的原因(特别是如果您sizeof(void*)sizeof(int)系统上不同)是线程启动例程的签名不正确。它应该返回一个void*,而不是一个int

man pthread_create

int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
                   void *(*start_routine) (void *), void *arg);

代码中也可能存在竞争条件 if popLogBuffer()usesg_logBufferStartIndex并且另一个线程正在修改它,因为它可能在if条件检查和popLogBuffer().

于 2012-10-18T08:18:12.687 回答
3

logInformation函数有一个错误的原型:它应该是void *logInformation(void *info).

你也应该通过它如下:

int ecode = pthread_create(&dwLogThread, NULL, logInformation, NULL);

最后,请注意pthread_create返回一个错误代码,即 0 表示一切正常。

于 2012-10-18T08:20:26.340 回答