zoukankan      html  css  js  c++  java
  • nj04---事件回调函数

    一、回调函数
            1.异步式读取文件
                    var fs=require('fs');
                    fs.readFile('file.txt','utf-8',function(err,data){
                        if(err){
                                console.log(err)
                         }else{
                                console.log(data)
                         }
                    });
                    console.log('end.')//先打印end,再打印内容
                结果:
                    end.
                    Contents of the file.
               2. 同步式读取文件
                   var fs=require('fs'); 
                    var data=fs.readFileSync('file.txt','utf-8');//没有回调函数
                    console.log(data)
                    console.log('end.')
                结果:
                    Contents of the file.
                    end.
               3.分析:
                    调用时所做的工作知识将异步式IO请求发送给了操作系统,然后立即返回并执行后面的语句,执行完以后进入事件循环监听事件,当fs接受到IO请求完成的事件时。事件循环会主动调用回调函数完成后续工作。同步则是阻塞等待完成后,继续执行。
     二、事件
                1.普通事件的使用
                        //声明事件对象`
                        var EventEmitter=require('events').EventEmitter;
                        var event=new EventEmitter();
                        //注册事件
                         event.on('some_event',function(){
                            console.log('这是一个自定义的事件');
                        });
                        //触发指定的事件
                        setTimeout(function(){
                            event.emit('some_event');
                        },1000);
                2.Node.js的事件循环机制
                    (1)Node.js在什么时候进入事件循环呢?
                            答案是Node.js程序是由事件循环开始,到事件循环结束,所有的逻辑都是事件的回调函数。一直循环看有没有没有执行的事件。
                    (2)如何使用自定义事件呢?
                            事件的回调函数在执行的过程中,可能会发出IO请求或直接发射(emit)事件,执行完毕后再返回事件循环。
  • 相关阅读:
    java课堂作业--异常处理
    Node.js 应用---定时给自己发送邮件
    JAVA课堂作业(2019.10.21)
    添加学生信息系统
    Hdfs的java必会Api操作
    架构之美2
    mybatis知识点03
    mybatis知识点总结02
    mybatis知识点总结01
    第四周周总结
  • 原文地址:https://www.cnblogs.com/yaowen/p/7012573.html
Copyright © 2011-2022 走看看