//程序一:模拟项目中的网络驱动程序(使用ssh启动远程程序端)
int main(){
std::string sUserName = "root"; //登录远程机器使用的用户名
std::string sPassword = "1234567980" //远程机器登录密码
std::string sCommand = "export DISPLAY=:0.0 /home/Test 127.0.0.1"
//使用ssh2执行命令启动远程机器Test应用程序,Test运行参数为127.0.0.1
Ssh2 ssh;
ssh.ExecuteCommand(sUserName,sPassword,sCommand);
return 1;
}
//程序二:模拟远程机器端(/home中有Test应用程序)
int main(){
getchar(); //Line 1
std::cout<<"========================"<<std::endl; //Line 2
FILE* fp = fopen("/home/Test_Out.txt","wb"); //Line 3
if(fp){
fwrite("open txt success",1,strlen("open txt success"),fp);
}
/*if(fp){ //Line 4
fclose(fp);
fp = NULL;
}*/
std::cout<<"执行一些输出操作"<<std::endl;
/*if(fp){ //Line 8
fclose(fp);
fp = NULL;
}*/
//中间操作1
/*if(fp){ //Line 7
fclose(fp);
fp = NULL;
}*/
//中间操作2
/*if(fp){ //Line 6
fclose(fp);
fp = NULL;
}*/
//。。。中间操作
/*if(fp){ //Line 5
fclose(fp);
fp = NULL;
}*/
if(fp){
fclose(fp);
fp = NULL;
}
return 1;
}
测试(操作验证步骤):
1.运行程序一,通过ssh启动远程机器中程序二Test程序,程序二确实被启动了,参数也传进来了,但中间有异常的地方,想调试程序二,但是看不见程序二的终端窗口,看不见输出信息;
2.猜想可能程序运行完后直接退出了,所以看不见终端窗口,所以在开头添加getchar()阻塞主程序往下运行,结果依然没有终端窗口显示;添加的Line 2输出行也没有显示(没有看见终端);
3.由于getchar()和输出====都不见效,怀疑Test程序是否被启动,所以添加了Line 3创建文件并输出内容,结果文件被创建了,但是内容有时候不能写入成功,在Line 4关闭文件,则内容被正常写入到文件中,注释Line 4,在Line 5处进行文件关闭,文件内容没有被输出,注释Line 4、5,在Line 6处关闭文件,文件内容依然没有被输出,多次定位关闭位置,逐步排除中间操作的影响,最终定位只有在Line 4处文件内容能正常被输出;
4.所以定位Line 4和Line 8中间的操作影响了文件内容的关闭导致文件内容没有被写入。Line 4和Line 8之间使用了std::cout输出操作;
5.将Line 4和Line 8之间的std::cout输出操作变成使用printf输出再次验证程序,文件内容正常被输出,将程序中使用到的std::cout操作都变成printf,文件在哪里关闭,内容都能正常输出到文件中,且程序运行正常;
6.所以综上测试,操作,验证,是由于使用std::cout导致程序中断操作,程序运行异常。
7.修改std::cout为printf进行输出,解决问题。
注意: 使用ssh通过export DISPLAY=:0.0启动远程机器程序时,远程机器中的程序被启动后,没有终端显示,且不能使用std::cout进行输出操作,否则远程机器程序终端退出。