创办动态链接库,使用自己的dll中的排序算法,用Qt将排序用时在界面上用表格的形式呈现出来
创建动态链接库,使用自己的dll中的排序算法,用Qt将排序用时在界面上用表格的形式呈现出来
首先创建动态链接库
打开vs2013,创建win32控制台应用程序项目,勾选dll及导出符号
完成后,就可以了
然后打开Qt,,创建Qt项目,都选默认值,
最后将Vs项目生成的.dll拷到Qt项目.exe文件所在的文件目录下(或者将Vs项目生成的.dll文件所在的目录设置环境变量)
Vs头文件代码:
// 下列 ifdef 块是创建使从 DLL 导出更简单的 // 宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 SORT_EXPORTS // 符号编译的。在使用此 DLL 的 // 任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将 // SORT_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的 // 符号视为是被导出的。 #ifdef SORT_EXPORTS #define SORT_API __declspec(dllexport) #else #define SORT_API __declspec(dllimport) #endif #include<iostream> #include<assert.h> #include<time.h> using namespace std; #define random(x) (rand()%x) // 此类是从 Sort.dll 导出的 //class SORT_API CSort { //public: // CSort(void); // // TODO: 在此添加您的方法。 //}; SORT_API int ShellSort(int *a, size_t size); SORT_API int QuickSort(int *a, size_t size); SORT_API int MergerSort(int *a, size_t size); SORT_API int HeapSort(int *a, size_t size);
Qt代码:
void MainWindow::on_pushButton_clicked() { unsigned int * arr = NULL; int col=0; int num[8] = { 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 200000000 }; for (int i =0; i <8; i++) { int row=0; cout << "n=" << num[i] << ":"; arr = new unsigned int[num[i]]; //**********************快速排序****************************************************************** for (int j = 0; j < num[i]; j++) { arr[j] = random(10000); } int ret = QuickSort((int *)arr, num[i]); ui->tableWidget->setItem(row++, col, new QTableWidgetItem(QString("%0").arg(ret))); qApp->processEvents(); //**********************快速排序****************************************************************** //**********************堆排序****************************************************************** for (int j = 0; j < num[i]; j++) { arr[j] = random(10000); } ret = HeapSort((int *)arr, num[i]); ui->tableWidget->setItem(row++, col, new QTableWidgetItem(QString("%0").arg(ret))); qApp->processEvents(); //**********************堆排序****************************************************************** //**********************插入排序****************************************************************** for (int j = 0; j < num[i]; j++) { arr[j] = random(10000); } ret = ShellSort((int *)arr, num[i]); ui->tableWidget->setItem(row++, col, new QTableWidgetItem(QString("%0").arg(ret))); qApp->processEvents(); //**********************插入排序****************************************************************** //**********************归并排序****************************************************************** for (int j = 0; j < num[i]; j++) { arr[j] = random(10000); } ret = MergerSort((int *)arr, num[i]); ui->tableWidget->setItem(row++, col, new QTableWidgetItem(QString("%0").arg(ret))); qApp->processEvents(); //**********************归并排序****************************************************************** col++; delete[]arr; } }