我有一个非常基本的程序,只有函数和变量并执行一些计算。构建部分很好。只有 cout、加法、乘法等非常基本的东西。
在 linux 上,程序在 eclipse cdt 上运行良好,(运行大约 3-4 秒)
当程序在visual studio 2010 c++上的windows 7上运行时,程序在带有MinGW的windows 7 eclipse c++上运行时花了163秒,很多
这里发生了什么??!!?!
编辑:我们不要称它为 c++,这里只是很多 C 函数,这是来自 main() 的代码
foutput1 = fopen(FILENAME1, "w");
foutput2 = fopen(FILENAME2, "w");
solveSystem();
OutputStepToFile();
iter++;
do
{
temporalExternalChange(tim);
do
{
solveSystem();
iter++;
} while (iter<T_FOUT);
iter = 0;
OutputStepToFile();
tim+=dt*T_FOUT;
if (fmod(tim,T_PRINT)<=0.0){cout << "\nt=" << tim << "ms";};
} while(tim<T_TOTAL);
SolveSystem() 是以下(部分),它只是对某些变量进行计算的函数:
void solveSystem()
{
fsGCcGMPformation(); // !cGMP formation
falp1AdAct_IP3form(); // !Norepinephrine receptor
fIVoCC(); // !Voltage dependent calcium current I_CaL
fIKv(); // !Delayed rectifier current I_K
fIBKCa(); // !Calcium-activated potassium
...
...
...
fVoltageChange();
performODEstep();
}
OutputStepToFile() 函数只是使用 C 风格的文件输出
void OutputStepToFile()
{
fprintf(foutput1,"%g %g %g %g %g %g %g %g ",V_m, tim, Ca_i, Na_i, K_i, Cl_i, Ca_u, Ca_r); // 1
fprintf(foutput1,"%g %g %g %g %g %g %g ",d_L, f_L, BKCa_a, KvD_a, KvD_i_slow, KvD_i_fast, KCNQ_a); // 8
fprintf(foutput1,"%g %g %g %g ",P_SOC, R_01, R_10, R_11); // 15
fprintf(foutput1,"%g %g %g %g %g %g %g %g %g\n", h_IP3, RS_G, RS_PG, G, IP3, PIP2, DAG, V_cGMP, cGMP); // 22
// Store Ca,K,Cl,Na ion channels
fprintf(foutput2,"%g %g %g %g %g %g %g %g %g ", I_CaL, I_CaT, I_BKCa, I_KvD, I_KCNQ, I_K2P, I_Kir, I_KATP, I_CaCC);
// Store ROCs/SOCs
fprintf(foutput2,"%g %g %g %g %g %g %g ", INa_NSC, IK_NSC, ICa_NSC, I_NSC, I_SOCNa, I_SOCCa, I_SOC);
// store SR dynamic currents, co-transporters, pumps and exchangers
fprintf(foutput2,"%g %g %g %g %g %g %g %g ", I_up, I_tr, I_rel, I_IP3, I_PMCA, I_NaK, I_NCX, I_NaKCl_Cl);
fprintf(foutput2,"%g %g %g %g %g %g\n", I_stim, V_cGMPbar, I_Catotm, I_Natotm, I_Cltotm, I_Ktotm);
}