fclose在android和linux上的工作方式不同

前端之家收集整理的这篇文章主要介绍了fclose在android和linux上的工作方式不同前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

以下计划:

  1. #include dio.h>
  2. #include

在ubuntu 11.04上显示-1,在ICS 4.0.3模拟器上显示2.找不到有关此问题的任何信息 – 我可以在两个平台上使此代码的工作类似吗? fredern在stderr上有同样的问题.

更新:

以前的小程序演示了我遇到的实际问题的原因:如果我尝试将freopen stderr文件存放在不存在的目录中,则在linux上stderr已关闭,但在android上它会保持打开状态!甚至更多 – 如果我在这个打开的stderr文件中写smth然后在其他文件上打开,我打印到stderr的文本被写入这个打开的文件.

那么,这个程序:

  1. #include dio.h>
  2. #include Failed" );
  3. if ( -1 != fileno( stderr ) ) {
  4. fclose( stderr );
  5. LOGD( "freopen closed" );
  6. }
  7. }
  8. LOGD(_T("TestFreopen stderr=0x%08x"),"fprintf_2 to stderr\n");
  9. TestFreopen_mkdir(); // case 2
  10. FILE* fopen_file = fopen( HOMEDIR "1.d/2",_T( "wb" ) );
  11. LOGD(_T("TestFreopen fopen_file=0x%08x"),fileno(fopen_file)); // same as for reopened stderr!!
  12. fprintf(stderr,"fprintf_3 to stderr\n");
  13. fprintf(fopen_file,"fprintf_1 to fopen_file\n");
  14. fflush(fopen_file);
  15. LOGD(_T("TestFreopen end"));
  16. }
  17. int main() {
  18. TestFreopen();
  19. return 0;
  20. }

在linux上显示

  1. $./a.out
  2. TestFreopen begin
  3. TestFreopen stderr=0x00000002
  4. fprintf_1 to stderr
  5. freopen Failed
  6. TestFreopen stderr=0xffffffff
  7. TestFreopen mkdirres=0x00000000
  8. TestFreopen fopen_file=0x00000002
  9. TestFreopen end
  10. $cat ~/1.d/2
  11. fprintf_1 to fopen_file

这在android上:

  1. $adb push ./a.out /data/data/com.myapp
  2. 573 KB/s (34635 bytes in 0.058s)
  3. $adb shell run-as com.myapp /data/data/com.myapp/a.out
  4. TestFreopen begin
  5. TestFreopen stderr=0x00000002
  6. fprintf_1 to stderr
  7. freopen Failed
  8. freopen closed
  9. TestFreopen stderr=0x00000002
  10. TestFreopen mkdirres=0x00000000
  11. TestFreopen fopen_file=0x00000002
  12. TestFreopen end
  13. $adb shell run-as com.myapp cat /data/data/com.myapp/1.d/2
  14. fprintf_3 to stderr
  15. fprintf_1 to fopen_file
最佳答案
在任何平台上关闭它之后尝试使用stderr没有任何意义.

猜你在找的Linux相关文章