2012-09-15 117 views
0

喜有一定的NodeJS代碼如下:如何知道nodejs進程完成?

console.log("Start", new Date().getTime()); 
var fs = require('fs'); 
for (var i = 1; i < 10; i++) { 
    fs.readFile("file1.zip",function(err, data) { 
     if(err) 
     console.log("read error: ", err); 
     else { 
      fs.writeFile(__dirname + "/file2.zip", data , function(err) { 
       if(err) { 
        console.log("write error: ", err); 
       }   
      }); 
     } 
    }); 
}; 
console.log("Finished", new Date().getTime()); 

我想要得到的開始,當所有的工作都做了結束時間,但它似乎是第二個日誌太早

回答

1

相反的console.log("Finished", new Date().getTime());你可能會想嘗試:

process.on('exit', function() { 
    console.log("Finished", new Date().getTime()); 
}); 
0

第二日誌函數被調用的太早,因爲節點的異步行爲。你必須把它放在最後的回調中:

console.log("Start", new Date().getTime()); 
var fs = require('fs'); 
for (var i = 1; i < 10; i++) { 
    fs.readFile("file1.zip",function(err, data) { 
    if(err) { 
     console.log("read error: ", err); 
    } else { 
     fs.writeFile(__dirname + "/file2.zip", data , function(err) { 
     if(err) { 
      console.log("write error: ", err); 
     } 
     // Put it here 
     console.log("Finished", new Date().getTime()); 
     }); 
    } 
    }); 
};