|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
怎么样出来了吧,怎么样自己也可以写出php程序了,虽然离职业和专业的人还有很远,但是好的开始是成功的一半。这个时候改怎么做了呢。现在就是拿1本高手推荐的书,重头到尾读1遍,我说的这个读是自己看。
此次仍是把碰到的几个成绩收拾整顿一下,但愿再碰到的同窗能轻松处理。别的比来博客的feeds延迟更新的缘由也会一同申明一下。
1.linux下创立线程招致内存泄露
明天在外网宣布了一个server以后,用top发明virt的利用量一向在涨,并且一次涨8m。因而可以判定有内存泄露了,经由排查,终究肯定缘由出在多线程的成绩上:
代码以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }
复制代码 在flush_thread_work函数外部:
- void* flush_thread_work(void* args) { //....do something return NULL; }
复制代码 代码中启动了一个线程以后,主历程就持续履行,任由新线程自生自灭了(没有挪用thread_join),而主历程每隔一段工夫就会拉起如许一个线程来做一些数据落地的工作。
如许的写法实践上是会形成内存泄露的.
Linux man page 里有已申明了这个成绩:
When a joinable thread terminates, its memory resources (thread descriptor and stack) are not deallocated until another thread performs pthread_join on it. Therefore, pthread_join must be called once for each joinable thread created to avoid memory leaks.
也就说线程履行完后假如不join的话,线程的资本会一向得不到释放而招致内存泄露!
处理办法有两种:
a.在线程履行的函数内手工释放
- void* flush_thread_work(void* args) { //....do something pthread_detach(pthread_self()); return NULL; }
复制代码 b.在线程启动时,设置线程的PTHREAD_CREATE_DETACHED属性
- 1 2 3 4 5 6 7 8 9 10 11 12 13 14
复制代码- pthread_attr_t attr; pthread_attr_init (&attr); pthread_attr_setdetachstate (&attr, PTHREAD_CREATE_DETACHED); int ret=pthread_create(&thread_id, &attr, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ //记住attr也要析构,不然
又是一个内存泄露
pthread_attr_destroy (&attr); APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; } //记住attr也要析构,不然
又是一个内存泄露
pthread_attr_destroy (&attr);
复制代码 如许成绩就能够处理了。
参考材料:
处理了一个荫蔽的内存泄露——pthread_create后没有detach招致内存延续增加
2.php的json_encode函数成绩
在公司做了一个使用,是php与c++停止收集交互,所以选择了json这类对照通用的序列化格局,但是却碰到了对照奇异的成绩。
先来看以下代码(php):
- $objs = array(); $objs[1] = 'a'; $objs[2] = 'b'; $objs[4] = 'd'; echo json_encode($objs)."\n";
复制代码 输入的了局以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }0
复制代码 如许是正常的,用jsoncpp也能够准确的解析出来,php主动将$objs看成一个联系关系数组来生成json数据了。
但是当把代码换成以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }2
复制代码 则输入了局以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }3
复制代码 jsoncpp依照之前的解析办法是解析不出来的~
其实对php来讲,这也是公道的,成绩在于在php外面通俗数组和联系关系数组都是array,而对c++来讲,却存在vector和map之分,所以假如仍是想要json_encode生成联系关系数组的格局,那末需求如许写:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }5
复制代码 了局以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }6
复制代码 3.本博feed延迟不更新的缘由
之前因为对feedsky的feed更新非常不满,所以参考网上的做法,创立了一个feed.vimer.cn,而本博地点的域名空间会主动依据域名创立一个子目次 - feed,修正这个目次下的.htaccess文件以下:
- pthread_t thread_id; int ret=pthread_create(&thread_id, NULL, flush_thread_work, (void*)&m_sql_client); if(ret!=0){ APPSCORE_ERROR("Thread creation failed:%d",ret); return ret; }8
复制代码 那末当会见 feed.vimer.cn 时,会主动跳转到 http://feed.feedsky.com/vimer。
但是我疏忽了一个成绩,那就是wordpress默许的feed链接是 http://vimer.cn/feed/rss2,而/feed/rss2会被解析成子目次,从而主动跳转到 http://feed.feedsky.com/vimer ,所以feedsky就会一直的读 http://feed.feedsky.com/vimer 这个链接的feed,固然不会有任何新数据。。
所以最初仍是把这类体例放弃失落了,看来真是冤枉了feedsky呀~~~
OK,比来的总结就这么多~
从刚开始练习的PHP基础语法练习,到PHP语言在WEB中的应用,再到实际的项目开发,如留言版,相册系统,中小型公司网站系统,以及期间做过的有关团队合作的小游戏,让我受益匪浅,学到了很多。 |
|