调用C的SDK,返回c_long类型,可以保存到临时变量中,也可以打印,为什么其他访问则报segmentation fault?

in0528
  • 3
新手上路,请多包涵

这段代码,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

回复
阅读 1.5k
1 个回答

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏