非线程安全,是不是可以理解成进程安全啊? 每个用户访问会话,启动一个进程。
你只要自己写代码,不要存在static 变量共享的问题,那么就都是安全的。
class dao{
   public static function getuserinfo($conn,....){
       static $db = $conn;
       $db->query('xxxx'); 
   }}偶是菜鸟,对线程不是很清楚。请高手指教啊。

解决方案 »

  1.   

    不要存在static 变量共享的问题,那么就都是安全的 这是什么意思
    static跟你说的那两个没关系 
    贴一段网上找来的PHP线程安全与非线程安全的区别Windows版的PHP从版本5.2.1开始有Thread Safe(线程安全)和None Thread Safe(NTS,非线程安全)之分,这两者不同在于何处?到底应该用哪种?这里做一个简单的介绍。   从2000年10月20日发布的第一个Windows版的PHP3.0.17开始的都是线程安全的版本,这是由于与Linux/Unix系统是采用多进程的工作方式不同的是Windows系统是采用多线程的工作方式。如果在IIS下以CGI方式运行PHP会非常慢,这是由于CGI模式是建立在多进程的基础之上的,而非多线程。一般我们会把PHP配置成以ISAPI的方式来运行,ISAPI是多线程的方式,这样就快多了。但存在一个问题,很多常用的PHP扩展是以Linux/Unix的多进程思想来开发的,这些扩展在ISAPI的方式运行时就会出错搞垮IIS。因此在IIS下CGI模式才是 PHP运行的最安全方式,但CGI模式对于每个HTTP请求都需要重新加载和卸载整个PHP环境,其消耗是巨大的。   为了兼顾IIS下PHP的效率和安全,微软给出了FastCGI的解决方案。FastCGI可以让PHP的进程重复利用而不是每一个新的请求就重开一个进程。同时FastCGI也可以允许几个进程同时执行。这样既解决了CGI进程模式消耗太大的问题,又利用上了CGI进程模式不存在线程安全问题的优势。   因此,如果是使用ISAPI的方式来运行PHP就必须用Thread Safe(线程安全)的版本;而用FastCGI模式运行PHP的话就没有必要用线程安全检查了,用None Thread Safe(NTS,非线程安全)的版本能够更好的提高效率。
      

  2.   

    不要存在static 变量共享的问题,那么就都是安全的 。
    就是静态方法里面,引用静态成员变量。class dao{
      private static $db;
      public static function getuserinfo($conn,....){
      $this->db = $conn;
      $db->query('xxxx'); 
      }}
      

  3.   

    站在php的层面讨论不了线程安全这个话题,php本身也不支持多线程。但是php的C源码要考虑这个问题,以适应不同的运行环境。
      

  4.   

    Yes,一次http请求开始结束就是一个php脚本进程的生命周期。
      

  5.   

    明白。
    不论:基于Linux/Unix的进程,还是Windows线程 的PHP。
    针对每一次用户访问,都会创建一个PHP脚本的副本。
    自己不要写下面这种代码就不会有问题:
    private static $conn ;
      

  6.   

    php不支持多线程的,
    接分
      

  7.   

    看看这个吧, 
    答复的典范啊.......http://stackoverflow.com/questions/1623914/what-is-thread-safe-or-non-thread-safe-in-php