看下面代码
import logging, configparser, sys, os, json, time, logging, sseclient, urllib3,re, threading, pandas as pd, datetime, requests from PyQt5.QtWidgets import QApplication, QWidget, QGridLayout logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s') from strategy.w_BigMidSmall_liangbi_pool import w_bms_liangbi class panel_trade(QWidget): def __init__(self): super(panel_trade, self).__init__() self.stock_idlist = 'abc' t = self.thread_login() t.start() def func(self, arg): print(arg) class thread_login(threading.Thread): def __init__(self): global panel_trade threading.Thread.__init__(self) def run(self) -> None: panel_trade.func(self,'ok') #第一次要加self panel_trade.func('ok') #第二次不要加self app = QApplication(sys.argv) panel_trade = panel_trade() panel_trade.show() sys.exit(app.exec_())
问题是:第一个func要加self,第二个不用加,否则报错,为什么?
原因很隐蔽:
首先我们看panel_trade这个既是一个类名,也是后面这个类的实例的命,容易出隐蔽错误。这个名字在子类panel_login里并定义为一个全局变量
其次,我们注意到在panel_trade的init函数里,就已经创建了子类panel_login 的实例并运行,这时候panel_trade的实例还没有创建(init函数全部执行完了才真正创建实例),所以在panel_login第一次调用panel_trade.func(self,'ok')时,这个panel_trade其实引用的是类,所以调用父类函数必须加self,而刚好这时父类init已经走完了最后一步(t.start()),这时候panel_login实例就已经创建了,而此时子类正在运行第二个 panel_trade.func('ok'),此时这里的panel_trade已经指向的是实例而不是类,因此就不能加self参数。