这段代码,user_id可以正常打印,但是赋值给self.user_id则报错,偶尔能够成功,SDK是第三方的
def _login(self, port):
username = 'admin'
password = ''
self.info('尝试登录', username, password)
# print user_id # , type(user_id) # , user_id.value
user_id = SDK.login(self.ip, port, username, password, self.device_info, self.error_code)
print 'temp user id', user_id # .value
# import pdb
# pdb.set_trace()
self.user_id = user_id
print 'continue'
print 'self.user_id', self.user_id # , user_id.value
打印信息如下:
temp user id 139955066556384
Segmentation fault
Segmentation fault ??? 这貌似是非法访问内存错误,出现这个错误会被linux系统强制杀死。
我感觉你出错的原因不是在 self.user_id = user_id上, 而是 user_id = SDK.login(),
之所以打印完就报错,应该是SDK.login()正在做释放啥操作导致Segmentation fault。
你可以在SDK.login()后 加一个 time.sleep(1) 验证出错不在self.user_id = user_id