Android NDK重新導向std::cout輸出到log

來源:互聯網
上載者:User

標籤:android ndk

第一步,繼承std::streambuf

#include <iostream>#include <streambuf>class MyStreamBuf : public std::streambuf{enum{BUFFER_SIZE = 255,};public:MyStreamBuf(){buffer_[BUFFER_SIZE] = '\0';setp(buffer_, buffer_ + BUFFER_SIZE - 1);}~MyStreamBuf(){sync();}protected:virtual int_type overflow(int_type c){if (c != EOF){*pptr() = c;pbump(1);}flush_buffer();return c;}virtual int sync(){flush_buffer();return 0;}private:int flush_buffer(){int len = int(pptr() - pbase());if (len <= 0)return 0;if (len <= BUFFER_SIZE)buffer_[len] = '\0';#ifdef ANDROID  android_LogPriority t = ANDROID_LOG_INFO;__android_log_write(t, "mylog", buffer_);#else  printf("%s", buffer_);#endif  pbump(-len);return len;}private:char buffer_[BUFFER_SIZE + 1];};

第二步,建立MyStreamBuf對象,並指定給std::cout

MyStreamBuf g_MyStreamBuf;std::cout.rdbuf(&g_MyStreamBuf);//NOTE: std::endl會立即調用sync方法將緩衝區字元寫入log,並不只是換行用std::cout << "hello " << 123 << std::endl;std::cout << "pi = " << 3.14 << std::endl;

這樣,就可以是Eclipse的LogCat查看std::cout輸出了。

Android NDK重新導向std::cout輸出到log

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.