Seg Fault 创建新的 QTcpSocket

Posted

技术标签:

【中文标题】Seg Fault 创建新的 QTcpSocket【英文标题】:Seg Fault creating new QTcpSocket 【发布时间】:2018-12-07 20:10:35 【问题描述】:

当我尝试创建新的 QTcpSocket 时遇到分段错误:

QTcpSocket* socket = new QTcpSocket();

当我运行时,我看到以下内容:

$ ./hello 
Hello World
Segmentation fault (core dumped)

我在 Unbuntu 17.04 上使用 Qt 5.11,但我没有使用 qmake。我已经创建了自己的 Makefile。我已经检查并仔细检查了 Qt 5.11 的包含和库,但不确定这是否是问题,因为我可以编译、链接和运行良好。

似乎有 2 组 Qt 分布所在的区域引起了一些混乱:

$(HOME)Qt5.11.1/5.11.1/gcc_64 
/usr/include/x86_64-linux-gnu/qt5

这是我的 Makefile 和代码。

hello.h

#ifndef HELLO_H
#define HELLO_H

#include <QObject>
#include <QTcpSocket>

class hello : public QObject

    Q_OBJECT
public:
    explicit hello(QObject *parent = 0);

signals:
    int test();

public slots:

private:

private slots:

;
#endif // HELLO_H

hello.cpp

#include "hello.h"

#include <QTcpSocket>
#include <QDebug>

hello::hello(QObject *parent) :
    QObject(parent)

    qDebug() << "Hello World\n";
    QTcpSocket* socket = new QTcpSocket(this);
    emit test();

ma​​in.cpp

#include <QCoreApplication>

#include "hello.h"

int main(int argc, char *argv[])

    QCoreApplication a(argc, argv);

    hello h;

    return a.exec();

生成文件

####### Compiler, tools and options

CC      =       g++
DEFINES =       -DQT_DEPRECATED_WARNINGS -DQT_NO_DEBUG -DQT_CORE_LIB
CFLAGS  =       -Wall -W -D_REENTRANT -fPIC $(DEFINES)
INCPATH =       -I. \
                -I$(HOME)/Qt5.11.1/5.11.1/gcc_64/include \
                -I$(HOME)/Qt5.11.1/5.11.1/gcc_64/include/QtCore \
                -I$(HOME)/Qt5.11.1/5.11.1/gcc_64/include/QtNetwork \
                -I$(HOME)/Qt5.11.1/5.11.1/gcc_64/mkspecs/linux-g++
LINK    =        g++
LFLAGS  =       -Wl,-O1 -Wl,-rpath,$(HOME)/Qt5.11.1/5.11.1/gcc_64/lib
LIBS    =       -L$(HOME)Qt5.11.1/5.11.1/gcc_64/lib \
                -L/usr/include/x86_64-linux-gnu/qt5/QtCore \
                -L/usr/include/x86_64-linux-gnu/qt5/QtNetwork \
                -lQt5Core -lQtNetwork
MOC     =       $(HOME)Qt5.11.1/5.11.1/gcc_64/bin/moc

####### Files

HEADERS =       hello.h
SOURCES =       hello.cpp \
                main.cpp
OBJECTS =       hello.o \
                main.o
SRCMOC  =       moc_hello.cpp
OBJMOC  =       moc_hello.o
TARGET  =       hello

####### Implicit rules

.SUFFIXES: .cpp

.cpp.o:
        $(CC) -c $(CFLAGS) $(INCPATH) -o $@ $<

####### Build rules

all: $(TARGET)

$(TARGET): $(OBJECTS) $(OBJMOC)
        $(LINK) $(LFLAGS) -o $(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS)

moc: $(SRCMOC)

clean:
        -rm -f $(OBJECTS) $(OBJMOC) $(SRCMOC) $(TARGET)
        -rm -f *~ core

####### Compile

hello.o: hello.cpp \
        hello.h \

main.o: main.cpp \
        hello.h \

moc_hello.o: moc_hello.cpp \
        hello.cpp \

moc_hello.cpp: hello.h

这是“ldd hello”的输出:

anshah@anshah-linux-laptop:~/test/hello$ ldd hello
linux-vdso.so.1 =>  (0x00007fff2bff4000)
libQt5Core.so.5 => /home/anshah/Qt5.11.1/5.11.1/gcc_64/lib/libQt5Core.so.5 (0x00007f5c4b903000)
libQtNetwork.so.4 => /usr/lib/x86_64-linux-gnu/libQtNetwork.so.4 (0x00007f5c4b582000)
libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f5c4b1fa000)
libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f5c4afe3000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f5c4ac1c000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f5c4a9fc000)
libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f5c4a7e0000)
libicui18n.so.56 => /home/anshah/Qt5.11.1/5.11.1/gcc_64/lib/libicui18n.so.56 (0x00007f5c4a347000)
libicuuc.so.56 => /home/anshah/Qt5.11.1/5.11.1/gcc_64/lib/libicuuc.so.56 (0x00007f5c49f8f000)
libicudata.so.56 => /home/anshah/Qt5.11.1/5.11.1/gcc_64/lib/libicudata.so.56 (0x00007f5c485ac000)
libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f5c483a8000)
libgthread-2.0.so.0 => /usr/lib/x86_64-linux-gnu/libgthread-2.0.so.0 (0x00007f5c481a4000)
libglib-2.0.so.0 => /lib/x86_64-linux-gnu/libglib-2.0.so.0 (0x00007f5c47e90000)
libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f5c47b87000)
/lib64/ld-linux-x86-64.so.2 (0x000056357a3b1000)
libQtCore.so.4 => /usr/lib/x86_64-linux-gnu/libQtCore.so.4 (0x00007f5c47695000)
libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f5c47422000)
librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f5c47218000)

【问题讨论】:

输出是什么:ldd hello 输出太长我把它放到“回答你的问题”待机中... 非常感谢顺便说一句 如果它太大然后edit你的问题并在那里添加 我建议你用 qmake 编译你的测试,看看你需要使用哪些标志。 【参考方案1】:

似乎有两组 Qt 分布所在的区域引起了一些混乱:

这很可能是您崩溃的根本原因。如果您针对来自 Qt 的一个版本的源代码(头文件)进行编译,然后在运行时使用 不同 版本,则很可能会发生崩溃。

但是,根本原因似乎不同:您使用的是 两个 版本的libQtCore

libQt5Core.so.5 => /home/anshah/Qt5.11.1/5.11.1/gcc_64/lib/libQt5Core.so.5

libQtNetwork.so.4 => /usr/lib/x86_64-linux-gnu/libQtNetwork.so.4
libQtCore.so.4 => /usr/lib/x86_64-linux-gnu/libQtCore.so.4

如果这些库定义了相同的符号(这似乎很可能),那么由于符号冲突和/或使用了错误的符号,您几乎肯定会遇到麻烦。

libQtCore.so.4 可能作为 libQtNetwork.so.4 的依赖项引入,您可能根本不应该依赖 libQtNetwork.so.4

您的Makefile 有:

-lQt5Core -lQtNetwork

最后一个条目应该是-lQt5Network

【讨论】:

我认为 Qt 4 的残余可能会导致冲突。您是否建议完全删除所有与 Qt 相关的模块并从最新的 5.11 重新开始? 彻底清除所有 Qt 残余并重新开始的最佳方法是什么?

以上是关于Seg Fault 创建新的 QTcpSocket的主要内容,如果未能解决你的问题,请参考以下文章

为 2D 数组调用 free() 会导致 seg。过错

QThread 和 QTcpSocket [关闭]

将现有的 QTcpSocket 变形为 QSslSocket

QTcpSocket 或 QSslSocket 会自动创建读/写线程吗?

进程共享变量#pragma data_seg用法

C++ Qt - QTcpSocket - 找不到文件