the diference between include and import

时间:2022-03-30 22:27:06

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