您好,登錄后才能下訂單哦!
近來用ollvm來編譯一些代碼,主要是需要對so進(jìn)行一些混淆的操作,發(fā)現(xiàn)了一個bug,記錄如下:
代碼段1
jint begin_antidebug() { pthread_t antidebugtid; int ret = 0; ret = pthread_create(&antidebugtid, NULL, antidebug_listen_thread, NULL); if(ret!=0) { LOGANTI("Create pthread error!\n"); exit (1); } return 0; }
上面的代碼段就是完成一個創(chuàng)建線程的邏輯,如果線程創(chuàng)建失敗,直接退出應(yīng)用,這段代碼不管用
android ndk默認(rèn)的編譯器或者是ollvm編譯器,運行結(jié)果都是按照代碼邏輯的。
但是如果代碼段2,如下
jint begin_antidebug() { pthread_t antidebugtid; int ret = 0; ret = pthread_create(&antidebugtid, NULL, antidebug_listen_thread, NULL); if(ret!=0) { LOGANTI("Create pthread error!\n"); exit (1); } }
這段代碼和上面的代碼比較,少了一個 return 0;這條語句
這個時候,兩種編譯器對于編譯的結(jié)果就有差異了
android ndk默認(rèn)編譯器 編譯出來的代碼依然能夠按照代碼邏輯運行。
而 ollvm編譯器編譯出來的代碼,ret優(yōu)化成0了,雖然線程創(chuàng)建成功了,但是進(jìn)程也執(zhí)行 exit(1);
退出了
防止這類bad code的方法,在Android.mk加入下面這行。
LOCAL_CFLAGS += -Werror
加強(qiáng)檢查類型,出現(xiàn)warning和error同樣處理
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。