mytransport->open()
在TSocket.cpp中调用GlobalOutput.perror("error code")
。但是在我的代码中,在mytransport->open()
初始化之前调用了GlobalOutput
请参阅this link了解详情
我有shared_ptr
名为mytransport
,我声明如下:
shared_ptr<TTransport> mytransport(new TBufferedTransport(socket));
但是当我调用mytransport->open();
时,我遇到了分段错误,并且堆栈跟踪的顶部显示:
#0 0x00000000 in ?? ()
#1 0x08068281 in apache::thrift::TOutput::perror (this=0x807a44c, message=0x9dc0e14 "TSocket::open() connect() <Host: localhost Port: 9090>", errno_copy=111) at src/thrift/Thrift.cpp:65
#2 0x080670eb in perror (errno_copy=<optimized out>, message=..., this=<optimized out>) at ./src/thrift/Thrift.h:123
#3 apache::thrift::transport::TSocket::openConnection (this=0xbfe69ea0, res=0xbfe69e9c) at src/thrift/transport/TSocket.cpp:277
我不太明白“ - &gt;”运算符,但似乎mytransport
指向NULL
对象。有什么想法吗?
编辑:如果我将代码放入主类中,它会正常运行并给出我想要的错误:
TSocket::open() connect() <Host: localhost Port: 9090>Connection refused
(参见堆栈跟踪上的#1)。但是,当我将代码放入库中的类(主类使用)时,就是当我得到分段错误时。那可能是某种范围问题?
答案 0 :(得分:1)
基于堆栈跟踪,在对TSocket.cpp
的代码进行一些研究后,line 182在openConnection()
方法上显示完全相同的错误消息。 errno_copy
从errno
获取值为111
的值。根据{{3}},该值对应ECONNREFUSED
。所以我会检查另一端的连接。