问题: python如何调用Qt带有GUI模块的DLL?



环境配置:

Win10 X64

Python 3.5.2 32 bit

Qt 5.5.1 MinGW 4.9.2 32.bit




Qt DLL代码实现:

extern "C" __declspec(dllexport)  void showMessageWindow(char *msg)
{
    QMessageBox::information(nullptr, "Title", msg);
}

extern "C" __declspec(dllexport) int add(int num1, int num2)
{
    return num1 + num2;
}

python调用代码:

from ctypes import *
dll = cdll.LoadLibrary("QtDllTest.dll")
print("add result=", dll.add(1, 2))
dll.showMessageWindow(b"Hello, Python Call C++!");

python执行结果:

图片说明

代码说明:
1. python正常调用add函数。执行结果打印出了"add result= 3";
2. python调用showMessageWindow失败。showMessageWindow设计GUI模块。



问题: python如何调用Qt带有GUI模块的DLL?


本人的探索:

  • python可以正常调用VC带UI的DLL.

  • 网上资料建议在可执行程序下,加入Qt5.5.1/5.5/mingw492_32的platforms和plugins目录下所有内容.结果仍然出现上面的错误.

4个回答

简单的话,把QT UI做一个进程,python启动这个进程

thinct
thinct 谢谢,不过我是想Qt封装一套SDK,然后Python可以针对API写一些简单的测试。
3 年多之前 回复

有个PYQT是做UI的

thinct
thinct 嗯,是的。因为我是想python直接调用,这样比较轻量级。在Linux下,甚至都不用安装Python都可以调用Qt生成的库文件。如此一来,我的测试程序,也可以完成跨平台任务。
3 年多之前 回复

问题已经解决了。。。

qq_30029123
qq_30029123 求指教
2 年多之前 回复
qq_30029123
qq_30029123 怎么解决的?
2 年多之前 回复

上一起自学吧看看那里资料多

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
ImportError: DLL load failed: 找不到指定的模块。

![图片说明](https://img-ask.csdn.net/upload/201608/01/1470040303_445967.png) caffe,,python,这是怎么回事,ImportError: DLL load failed: 找不到指定的模块。

从PHP脚本(GNU Radio Python)在Python中启动Qt

<div class="post-text" itemprop="text"> <p>I am currently working on a GNU Radio project to generate analog signal from an USRP. I have to create a local html page to control this. </p> <p>So in my php script (first_php.php), I have : </p> <pre><code>&lt;?php //echo exec('python testpython.py'); // Test python script : works ! echo shell_exec("./testscript.sh"); // Echo to see the output echo '&lt;br/&gt;Current script owner: ' . get_current_user(); ?&gt; </code></pre> <p>In testscript.sh, I have</p> <pre><code>python top_block.py &amp; </code></pre> <p>My Python script is quite extensive, but basically, in the main function, I am calling "Qt.QApplication(sys.argv)" and it doesn't work. </p> <p>The python code is the following : </p> <pre><code># -*- coding: utf-8 -*- ################################################## # GNU Radio Python Flow Graph # Title: Top Block # Generated: Mon Jul 3 14:59:12 2017 ################################################## print "Starting Top Block Execution &lt;br/&gt;" if __name__ == '__main__': import ctypes import sys if sys.platform.startswith('linux'): try: x11 = ctypes.cdll.LoadLibrary('libX11.so') x11.XInitThreads() except: print "Warning: failed to XInitThreads()" print "Step 1 : Imports &lt;br/&gt;" import os print " - Step 1.1 : Importing [os] &lt;br/&gt;" import sys print " - Step 1.2 : Importing [sys] &lt;br/&gt;" print " - - Step 1.2.1 : Adding correct PATH to [sys.path] &lt;br/&gt;" sys.path.append(os.environ.get('GRC_HIER_PATH', os.path.expanduser('~/.grc_gnuradio'))) print " - - " print sys.path print "&lt;br/&gt;" print " - - Step 1.2.1 : Adding DME_station PATH to [sys.path] &lt;br/&gt;" sys.path.append('/home/myusername/.grc_gnuradio') print " - - " print sys.path print "&lt;br/&gt;" print " - Step 1.3 : Importing [DME_station] &lt;br/&gt;" from DME_station import DME_station # grc-generated hier_block print " - Step 1.4 : Importing [PyQt4] from [Qt] &lt;br/&gt;" from PyQt4 import Qt print " - Step 1.5 : Importing [blocks] from [gnuradio]&lt;br/&gt;" from gnuradio import blocks print " - Step 1.6 : Importing [eng_notation] from [gnuradio]&lt;br/&gt;" from gnuradio import eng_notation print " - Step 1.7 : Importing [gr] from [gnuradio]&lt;br/&gt;" from gnuradio import gr print " - Step 1.8 : Importing [qtgui] from [gnuradio]&lt;br/&gt;" from gnuradio import qtgui print " - Step 1.9 : Importing [eng_option] from [gnuradio.eng_option]&lt;br/&gt;" from gnuradio.eng_option import eng_option print " - Step 1.10 : Importing [firdes] from [gnuradio.filter]&lt;br/&gt;" from gnuradio.filter import firdes print " - Step 1.11 : Importing [OptionParser] from [optparse]&lt;br/&gt;" from optparse import OptionParser print " - Step 1.12 : Importing [DME]&lt;br/&gt;" import DME print " - Step 1.13 : Importing [sip]&lt;br/&gt;" import sip print " - Step 1.14 : Importing [threading]&lt;br/&gt;" import threading print " - Step 1.15 : Importing [time]&lt;br/&gt;" import time print "Step 2 : class top_block &lt;br/&gt;" class top_block(gr.top_block, Qt.QWidget): def __init__(self): gr.top_block.__init__(self, "Top Block") Qt.QWidget.__init__(self) self.setWindowTitle("Top Block") try: self.setWindowIcon(Qt.QIcon.fromTheme('gnuradio-grc')) except: pass self.top_scroll_layout = Qt.QVBoxLayout() self.setLayout(self.top_scroll_layout) self.top_scroll = Qt.QScrollArea() self.top_scroll.setFrameStyle(Qt.QFrame.NoFrame) self.top_scroll_layout.addWidget(self.top_scroll) self.top_scroll.setWidgetResizable(True) self.top_widget = Qt.QWidget() self.top_scroll.setWidget(self.top_widget) self.top_layout = Qt.QVBoxLayout(self.top_widget) self.top_grid_layout = Qt.QGridLayout() self.top_layout.addLayout(self.top_grid_layout) self.settings = Qt.QSettings("GNU Radio", "top_block") self.restoreGeometry(self.settings.value("geometry").toByteArray()) ################################################## # Variables ################################################## self.d_nm = d_nm = 10 self.DMEOutputFreq_0 = DMEOutputFreq_0 = 0 self.DMEInputFreq_0 = DMEInputFreq_0 = 0 self.variable_qtgui_label_0_1 = variable_qtgui_label_0_1 = DMEInputFreq_0 self.variable_qtgui_label_0_0_0 = variable_qtgui_label_0_0_0 = DMEOutputFreq_0 self.samp_rate = samp_rate = 10000000 self.k = k = 0.0 self.d_m = d_m = float((d_nm*1852)) self.c = c = 299792458.0 self.NAV = NAV = 108000000 ################################################## # Blocks ################################################## self.widget = Qt.QTabWidget() self.widget_widget_0 = Qt.QWidget() self.widget_layout_0 = Qt.QBoxLayout(Qt.QBoxLayout.TopToBottom, self.widget_widget_0) self.widget_grid_layout_0 = Qt.QGridLayout() self.widget_layout_0.addLayout(self.widget_grid_layout_0) self.widget.addTab(self.widget_widget_0, "DME_Generator/Detector Test") self.widget_widget_1 = Qt.QWidget() self.widget_layout_1 = Qt.QBoxLayout(Qt.QBoxLayout.TopToBottom, self.widget_widget_1) self.widget_grid_layout_1 = Qt.QGridLayout() self.widget_layout_1.addLayout(self.widget_grid_layout_1) self.widget.addTab(self.widget_widget_1, "DME_Response Test") self.widget_widget_2 = Qt.QWidget() self.widget_layout_2 = Qt.QBoxLayout(Qt.QBoxLayout.TopToBottom, self.widget_widget_2) self.widget_grid_layout_2 = Qt.QGridLayout() self.widget_layout_2.addLayout(self.widget_grid_layout_2) self.widget.addTab(self.widget_widget_2, "Final Simulation") self.widget_widget_3 = Qt.QWidget() self.widget_layout_3 = Qt.QBoxLayout(Qt.QBoxLayout.TopToBottom, self.widget_widget_3) self.widget_grid_layout_3 = Qt.QGridLayout() self.widget_layout_3.addLayout(self.widget_grid_layout_3) self.widget.addTab(self.widget_widget_3, "Station Block Simulation") self.top_layout.addWidget(self.widget) self._d_nm_tool_bar = Qt.QToolBar(self) self._d_nm_tool_bar.addWidget(Qt.QLabel("d_nm"+": ")) self._d_nm_line_edit = Qt.QLineEdit(str(self.d_nm)) self._d_nm_tool_bar.addWidget(self._d_nm_line_edit) self._d_nm_line_edit.returnPressed.connect( lambda: self.set_d_nm(int(str(self._d_nm_line_edit.text().toAscii())))) self.widget_layout_3.addWidget(self._d_nm_tool_bar) self._NAV_tool_bar = Qt.QToolBar(self) self._NAV_tool_bar.addWidget(Qt.QLabel("NAV"+": ")) self._NAV_line_edit = Qt.QLineEdit(str(self.NAV)) self._NAV_tool_bar.addWidget(self._NAV_line_edit) self._NAV_line_edit.returnPressed.connect( lambda: self.set_NAV(int(str(self._NAV_line_edit.text().toAscii())))) self.widget_layout_3.addWidget(self._NAV_tool_bar) self.DME_station_0 = DME_station( NAV_freq=NAV, d_nm=10, ) self._variable_qtgui_label_0_1_tool_bar = Qt.QToolBar(self) if None: self._variable_qtgui_label_0_1_formatter = None else: self._variable_qtgui_label_0_1_formatter = lambda x: x self._variable_qtgui_label_0_1_tool_bar.addWidget(Qt.QLabel("DME Input Frequency"+": ")) self._variable_qtgui_label_0_1_label = Qt.QLabel(str(self._variable_qtgui_label_0_1_formatter(self.variable_qtgui_label_0_1))) self._variable_qtgui_label_0_1_tool_bar.addWidget(self._variable_qtgui_label_0_1_label) self.widget_layout_3.addWidget(self._variable_qtgui_label_0_1_tool_bar) self._variable_qtgui_label_0_0_0_tool_bar = Qt.QToolBar(self) if None: self._variable_qtgui_label_0_0_0_formatter = None else: self._variable_qtgui_label_0_0_0_formatter = lambda x: x self._variable_qtgui_label_0_0_0_tool_bar.addWidget(Qt.QLabel("DME Output Frequency"+": ")) self._variable_qtgui_label_0_0_0_label = Qt.QLabel(str(self._variable_qtgui_label_0_0_0_formatter(self.variable_qtgui_label_0_0_0))) self._variable_qtgui_label_0_0_0_tool_bar.addWidget(self._variable_qtgui_label_0_0_0_label) self.widget_layout_3.addWidget(self._variable_qtgui_label_0_0_0_tool_bar) self.qtgui_time_sink_x_0_0_1_0_0_0 = qtgui.time_sink_f( 2048, #size samp_rate, #samp_rate "Response Generator", #name 2 #number of inputs ) self.qtgui_time_sink_x_0_0_1_0_0_0.set_update_time(0.05) self.qtgui_time_sink_x_0_0_1_0_0_0.set_y_axis(-1, 1) self.qtgui_time_sink_x_0_0_1_0_0_0.set_y_label("Amplitude", "") self.qtgui_time_sink_x_0_0_1_0_0_0.enable_tags(-1, True) self.qtgui_time_sink_x_0_0_1_0_0_0.set_trigger_mode(qtgui.TRIG_MODE_FREE, qtgui.TRIG_SLOPE_POS, 0.0, 0, 0, "") self.qtgui_time_sink_x_0_0_1_0_0_0.enable_autoscale(False) self.qtgui_time_sink_x_0_0_1_0_0_0.enable_grid(False) self.qtgui_time_sink_x_0_0_1_0_0_0.enable_control_panel(True) if not True: self.qtgui_time_sink_x_0_0_1_0_0_0.disable_legend() labels = ["", "", "", "", "", "", "", "", "", ""] widths = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1] colors = ["blue", "red", "green", "black", "cyan", "magenta", "yellow", "dark red", "dark green", "blue"] styles = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1] markers = [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1] alphas = [1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0] for i in xrange(2): if len(labels[i]) == 0: self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_label(i, "Data {0}".format(i)) else: self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_label(i, labels[i]) self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_width(i, widths[i]) self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_color(i, colors[i]) self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_style(i, styles[i]) self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_marker(i, markers[i]) self.qtgui_time_sink_x_0_0_1_0_0_0.set_line_alpha(i, alphas[i]) self._qtgui_time_sink_x_0_0_1_0_0_0_win = sip.wrapinstance(self.qtgui_time_sink_x_0_0_1_0_0_0.pyqwidget(), Qt.QWidget) self.widget_layout_3.addWidget(self._qtgui_time_sink_x_0_0_1_0_0_0_win) self.blocks_throttle_0_0 = blocks.throttle(gr.sizeof_float*1, samp_rate/10,True) self.DME_Pulse_Generator_0_0 = DME.Pulse_Generator(samp_rate) def _DMEOutputFreq_0_probe(): while True: val = self.DME_station_0.DME_Pairing_VOR_DME_0.getDMEOutputFreq() try: self.set_DMEOutputFreq_0(val) except AttributeError: pass time.sleep(1.0 / (10)) _DMEOutputFreq_0_thread = threading.Thread(target=_DMEOutputFreq_0_probe) _DMEOutputFreq_0_thread.daemon = True _DMEOutputFreq_0_thread.start() def _DMEInputFreq_0_probe(): while True: val = self.DME_station_0.DME_Pairing_VOR_DME_0.getDMEInputFreq() try: self.set_DMEInputFreq_0(val) except AttributeError: pass time.sleep(1.0 / (10)) _DMEInputFreq_0_thread = threading.Thread(target=_DMEInputFreq_0_probe) _DMEInputFreq_0_thread.daemon = True _DMEInputFreq_0_thread.start() ################################################## # Connections ################################################## self.connect((self.DME_Pulse_Generator_0_0, 0), (self.blocks_throttle_0_0, 0)) self.connect((self.DME_station_0, 0), (self.qtgui_time_sink_x_0_0_1_0_0_0, 1)) self.connect((self.blocks_throttle_0_0, 0), (self.DME_station_0, 0)) self.connect((self.blocks_throttle_0_0, 0), (self.qtgui_time_sink_x_0_0_1_0_0_0, 0)) def closeEvent(self, event): self.settings = Qt.QSettings("GNU Radio", "top_block") self.settings.setValue("geometry", self.saveGeometry()) event.accept() def get_d_nm(self): return self.d_nm def set_d_nm(self, d_nm): self.d_nm = d_nm self.set_d_m(float((self.d_nm*1852))) Qt.QMetaObject.invokeMethod(self._d_nm_line_edit, "setText", Qt.Q_ARG("QString", str(self.d_nm))) def get_DMEOutputFreq_0(self): return self.DMEOutputFreq_0 def set_DMEOutputFreq_0(self, DMEOutputFreq_0): self.DMEOutputFreq_0 = DMEOutputFreq_0 self.set_variable_qtgui_label_0_0_0(self._variable_qtgui_label_0_0_0_formatter(self.DMEOutputFreq_0)) def get_DMEInputFreq_0(self): return self.DMEInputFreq_0 def set_DMEInputFreq_0(self, DMEInputFreq_0): self.DMEInputFreq_0 = DMEInputFreq_0 self.set_variable_qtgui_label_0_1(self._variable_qtgui_label_0_1_formatter(self.DMEInputFreq_0)) def get_variable_qtgui_label_0_1(self): return self.variable_qtgui_label_0_1 def set_variable_qtgui_label_0_1(self, variable_qtgui_label_0_1): self.variable_qtgui_label_0_1 = variable_qtgui_label_0_1 Qt.QMetaObject.invokeMethod(self._variable_qtgui_label_0_1_label, "setText", Qt.Q_ARG("QString", str(self.variable_qtgui_label_0_1))) def get_variable_qtgui_label_0_0_0(self): return self.variable_qtgui_label_0_0_0 def set_variable_qtgui_label_0_0_0(self, variable_qtgui_label_0_0_0): self.variable_qtgui_label_0_0_0 = variable_qtgui_label_0_0_0 Qt.QMetaObject.invokeMethod(self._variable_qtgui_label_0_0_0_label, "setText", Qt.Q_ARG("QString", str(self.variable_qtgui_label_0_0_0))) def get_samp_rate(self): return self.samp_rate def set_samp_rate(self, samp_rate): self.samp_rate = samp_rate self.qtgui_time_sink_x_0_0_1_0_0_0.set_samp_rate(self.samp_rate) self.blocks_throttle_0_0.set_sample_rate(self.samp_rate/10) def get_k(self): return self.k def set_k(self, k): self.k = k def get_d_m(self): return self.d_m def set_d_m(self, d_m): self.d_m = d_m def get_c(self): return self.c def set_c(self, c): self.c = c def get_NAV(self): return self.NAV def set_NAV(self, NAV): self.NAV = NAV Qt.QMetaObject.invokeMethod(self._NAV_line_edit, "setText", Qt.Q_ARG("QString", str(self.NAV))) self.DME_station_0.set_NAV_freq(self.NAV) print "Step 3 : main function definition &lt;br/&gt;" def main(top_block_cls=top_block, options=None): from distutils.version import StrictVersion print " - Step 3.1 : Setting Qt version, style" if StrictVersion(Qt.qVersion()) &gt;= StrictVersion("4.5.0"): print " - - Step 3.1.1 : Setting Qt style" style = gr.prefs().get_string('qtgui', 'style', 'raster') Qt.QApplication.setGraphicsSystem(style) print " - - Step 3.1.1 : Setting Qt app" qapp = Qt.QApplication(sys.argv) print " - Step 3.2 : Initializing, starting and showing tob block" tb = top_block_cls() tb.start() tb.show() def quitting(): tb.stop() tb.wait() qapp.connect(qapp, Qt.SIGNAL("aboutToQuit()"), quitting) qapp.exec_() if __name__ == '__main__': main() print "Top Block Output " </code></pre> <p>I am using Ubuntu 16.04.1 on a Parallels Desktop VM,aAnd I am trying to accomplish this either from Safari browser (macOS Sierra) or Chrome (Ubuntu on the VM). The script's behavior is the same in either case (including "localhost" instead of IP dress in Chrome)</p> <p>I have added prints to the Python code to analyse where the code stops running. The output in the html page is : </p> <pre><code>Starting Top Block Execution Step 1 : Imports - Step 1.1 : Importing [os] - Step 1.2 : Importing [sys] - - Step 1.2.1 : Adding correct PATH to [sys.path] - - ['/var/www/html', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-x86_64-linux-gnu', '/usr/lib/python2.7/lib-tk', '/usr/lib/python2.7/lib-old', '/usr/lib/python2.7/lib-dynload', '/usr/local/lib/python2.7/dist-packages', '/usr/lib/python2.7/dist-packages', '/usr/lib/python2.7/dist-packages/PILcompat', '/usr/lib/python2.7/dist-packages/gtk-2.0', '/usr/lib/python2.7/dist-packages/wx-3.0-gtk2', '/var/www/.grc_gnuradio'] - - Step 1.2.1 : Adding DME_station PATH to [sys.path] - - ['/var/www/html', '/usr/lib/python2.7', '/usr/lib/python2.7/plat-x86_64-linux-gnu', '/usr/lib/python2.7/lib-tk', '/usr/lib/python2.7/lib-old', '/usr/lib/python2.7/lib-dynload', '/usr/local/lib/python2.7/dist-packages', '/usr/lib/python2.7/dist-packages', '/usr/lib/python2.7/dist-packages/PILcompat', '/usr/lib/python2.7/dist-packages/gtk-2.0', '/usr/lib/python2.7/dist-packages/wx-3.0-gtk2', '/var/www/.grc_gnuradio', '/home/clovel/.grc_gnuradio'] - Step 1.3 : Importing [DME_station] - Step 1.4 : Importing [PyQt4] from [Qt] - Step 1.5 : Importing [blocks] from [gnuradio] - Step 1.6 : Importing [eng_notation] from [gnuradio] - Step 1.7 : Importing [gr] from [gnuradio] - Step 1.8 : Importing [qtgui] from [gnuradio] - Step 1.9 : Importing [eng_option] from [gnuradio.eng_option] - Step 1.10 : Importing [firdes] from [gnuradio.filter] - Step 1.11 : Importing [OptionParser] from [optparse] - Step 1.12 : Importing [DME] - Step 1.13 : Importing [sip] - Step 1.14 : Importing [threading] - Step 1.15 : Importing [time] Step 2 : class top_block Step 3 : main function definition - Step 3.1 : Setting Qt version, style - - Step 3.1.1 : Setting Qt style - - Step 3.1.1 : Setting Qt app Current script owner: www-data </code></pre> <p>If I use "exec" instead of "shell_exec", the output is only : </p> <pre><code>- - Step 3.1.1 : Setting Qt app Current script owner: www-data </code></pre> <p>I am new to HTML/PHP coding. This is my first question on StackOverflow. Don't hesitate to tell me if info is missing. </p> <p>Thanks a lot for your time, Clovel</p> <p><strong>EDIT 1 :</strong> It works seamlessly with the "php first_php.php" command in the terminal</p> </div>

ImportError: Failed to import any qt binding

pip uninstall matplotlib python -m pip install --upgrade pip pip install matplotlib 任然未能解决问题

用cxfreeze打包后exe文件报错找不到指定模块

如题,经查找后是找不到PyQt5下的QtCore, QtGui, QtWidgets模块 这个exe文件在我的电脑上运行没有问题,但是在别人的电脑上运行就会报错: ImportError:找不到指定的模块 请问这个问题该如何解决?

QT调用外部函数之后再操作系统控件的话就会段错误死掉

加急啊,不知道为什么调用外部函数之后操作控件就死掉了,操作函数之前调用控件都可以,把ui::Diagnostic *ui,放到public也没有用,郁闷透了

python程序使用cx_freeze打包后只在本机可以打开拷贝到别的电脑上就打不开

python程序使用cx_freeze打包后只在本机可以打开,把exe程序拷贝到别的电脑上就打不开是什么原因呢?求助各位大大!!![图片说明](https://img-ask.csdn.net/upload/201903/07/1551945985_983929.jpg) 错误提示为:line9 ImportError:DLL load failed:找不到指定的模块 第九行代码为from PyQt4 import QtCore, QtGui 但我在打包成exe的那个文件夹的lib目录下找得到PyQt4中的QtGui4.dll和QtCore4.dll文件。 谢谢各位大大了。

C# 使用 Widgets must be created in the GUI thread

在使用C#调用qt的dll时,第一次调用的一般没事,第二,三次就会出现Widgets must be created in the GUI thread。 这是我用的qt中的代码 BOOL WINAPI DllMain( HINSTANCE hInstance, DWORD dwReason, LPVOID /*lpvReserved*/ ) { static bool ownApplication = FALSE; if ( dwReason == DLL_PROCESS_ATTACH ) { ownApplication = QMfcApp::pluginInstance( hInstance ); } if ( dwReason == DLL_PROCESS_DETACH && ownApplication ) { delete qApp; } return TRUE; } 这是C#中调用qt的代码 myfun1 = new DLDApi(); myfun1.LoadDll(@"D:\MvcAAA\MvcAAA\bin\meshlab.dll"); // 加载 "Count.dll" myfun1.LoadFun("Test"); // 调入函数 count, "_count@4" 是它的入口,可通过 Depends 查看 object[] Parameters = new object[] { (int)5}; // 实参为 0 Type[] ParameterTypes = new Type[] { typeof(int) }; // 实参类型为 int DLDApi.ModePass[] themode = new DLDApi.ModePass[] { DLDApi.ModePass.ByValue }; // 传送方式为值传 Type Type_Return = typeof(int); // 返回类型为 int // 弹出提示框,显示调用 myfun.Invoke 方法的结果,即调用 count 函数 int i = (int)myfun1.Invoke(Parameters, ParameterTypes, themode, Type_Return); myfun1.UnLoadDll(); C#代码在运行**UnLoadDll**卸载dll方法后,DLL_PROCESS_DETACH中断delete app并没有被执行,整个dll里面有一个qt的线程,卸载了dll后线程并没有被关闭,导致第二次运行的时候无法再次创建QWidegt对象。 想要请教以下各位,如何让在调用完dll后让中的线程关闭掉。是应该写在C++的这个dll中还是写在C#的调用中, 同时这个qt的dll中有一个对象My3Doperation,这个对象继承与QWidget,如何在使用完这个对象后将创建的线程彻底删除。 extern "C" __declspec(dllexport) int Test(int fileName) { My3Doperation model; //计算代码 return fileName+5; }

pyqt打包,出现问题,不知道怎样解决

使用pyinstaller 打包时出现错误 ``` Unable to find "D:\anaconda3\lib\site-packages\PyQt5\Qt\translations\qtwebengine_locales" when adding binary and data files. ```

No such file or directory

在win7安装qt4下运行main.cpp:8: error: QApplication: No such file or directory #include <QApplication> (#include <QtGui/QApplication>) ^ ![图片说明](https://img-ask.csdn.net/upload/201503/27/1427464089_487413.png)

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

Linux 会成为主流桌面操作系统吗?

整理 |屠敏出品 | CSDN(ID:CSDNnews)2020 年 1 月 14 日,微软正式停止了 Windows 7 系统的扩展支持,这意味着服役十年的 Windows 7,属于...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

学习总结之HTML5剑指前端(建议收藏,图文并茂)

前言学习《HTML5与CSS3权威指南》这本书很不错,学完之后我颇有感触,觉得web的世界开明了许多。这本书是需要有一定基础的web前端开发工程师。这本书主要学习HTML5和css3,看...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

新一代神器STM32CubeMonitor介绍、下载、安装和使用教程

关注、星标公众号,不错过精彩内容作者:黄工公众号:strongerHuang最近ST官网悄悄新上线了一款比较强大的工具:STM32CubeMonitor V1.0.0。经过我研究和使用之...

记一次腾讯面试,我挂在了最熟悉不过的队列上……

腾讯后台面试,面试官问:如何自己实现队列?

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

冒泡排序动画(基于python pygame实现)

本项目效果初始截图如下 动画见本人b站投稿:https://www.bilibili.com/video/av95491382 本项目对应github地址:https://github.com/BigShuang python版本:3.6,pygame版本:1.9.3。(python版本一致应该就没什么问题) 样例gif如下 ======================= 大爽歌作,mad

Redis核心原理与应用实践

Redis核心原理与应用实践 在很多场景下都会使用Redis,但是到了深层次的时候就了解的不是那么深刻,以至于在面试的时候经常会遇到卡壳的现象,学习知识要做到系统和深入,不要把Redis想象的过于复杂,和Mysql一样,是个读取数据的软件。 有一个理解是Redis是key value缓存服务器,更多的优点在于对value的操作更加丰富。 安装 yum install redis #yum安装 b...

现代的 “Hello, World”,可不仅仅是几行代码而已

作者 |Charles R. Martin译者 | 弯月,责编 | 夕颜头图 |付费下载自视觉中国出品 | CSDN(ID:CSDNnews)新手...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

01、Java入门(Getting Started);02、集成开发环境(IDE);03、项目结构(Eclipse JavaProject);04、类和对象(Classes and Objects);05:词法结构(Lexical Structure);06:数据类型和变量(Data Type and Variables);07:运算符(Operators);08:控制流程语句(Control Flow Statements);

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

立即提问
相关内容推荐