• the diference between include and import


    There is an interesting article here regarding the difference between import and `include when it comes to packages. I'm going to attempt to summarise it here.

    When you `include a file, it is basically saying take the contents of that file and paste it at the location of the include statement. This is effectively the same behaviour as #include in C/C++.

    Great you are thinking, now we have everything in the file, why can't we just use it? Imagine the case though where you are declaring a package in SV. If you `include a file containing a class A into two different packages P and Q, you are basically making a different copy of it in each package, which because of the way SV handles types will be incompatible (you now have one class called P::A and another called Q::A).

    This is where import comes in. Unlike `include, the import statement does not copy the definitions being brought in to the file, instead it simply makes them visible. This is similar to the way the using namespace works in C++. Lets say you still `include the class A in package P as before. But now, rather than including A directly in package Q, you import P::A instead, both P and Q now contain the same class P::A instead of having two different ones.

    So in summary:

    • `include copies the contents of the file in making a local copy of any classes/types/etc.
    • import doesn't copy but rather makes the existing package declarations visible in the current file

    Consider one question, how to address scope visibility of identifier

    import content should be compiled once; while include content should not be compiled

    import is statement which must be followed by simicolon, include is preprocessor indirective which not need

    the class and type which is include at diffrent place, will not be treated as the same object, while import assure the 

    coherence

     

  • 相关阅读:
    Oracle学习笔记:使用replace、regexp_replace实现字符替换、姓名脱敏
    Oracle学习笔记:外连接(+)的用法
    Oracle学习笔记:with as子查询用法
    Oracle学习笔记:a inner join b与from a,b where a.x=b.x的差异
    oracle查看表,索引,视图,存储过程的定义
    oracle查看监听状态
    由sock引起的感想
    xargs
    oracle知识点小结1
    Oracle系统权限列表
  • 原文地址:https://www.cnblogs.com/air-of-code/p/10478735.html
Copyright © 2020-2023  润新知