在回答这个问题之前希望大家大概了解一个文件编译的过程,比如一个C文件在编译成功后文件夹里的文件会有什么变化,大家可以先去创建一个helloworld.c的文件,观察其编译后的变化。
那么问题来了 面试官经常会问到动态链接和静态链接的区别,这到底是什么鬼,作为马上面试的小白如何快速理解这道题呢~ 不要急
这道题我们要理解动态库和静态库区别,
1,了解其文件命名格式
静态库:linux下 libxxx.a windows下xxx.lib
动态库:linux下libxxx.so windows下xxx.dll
2,了解含义区别
静态库:LIB包含函数代码本身,在编译时直接将代码加入程序当中
动态库:LIB包含了函数所在的DLL文件和文件中函数位置的信息,代码由运行时加载在进程空间中的DLL提供
静态链接需要静态库:链接器从静态链接库LIB获取所有被引用函数,并将库同代码一起放到可执行文件中。
动态链接需要动态库:允许可执行模块(.dll文件或.exe文件)仅包含在运行时定位DLL中函数的可执行代码所需的信息。
3,实战例子一语中的
在输入url中,我们发现有的url带❓ 有的url不带❓
那么这个❓问号就是判断动态链接和静态链接的不二法门。
举一个例子:
动态链接:https://www.xuewangzhan.net/?p=388
静态链接:https://www.xuewangzhan.net/zichu/468.html
打开两个网站得到的内容会完全一样,然而这个❓就是区分二者的关键
伪静态设置后(动态链接—静态链接 只需要上传伪静态文件)可以优化网站排名,说白了就是在百度,谷歌等搜索引擎排名靠前 更易出现在结果,所以这也是静态链接的优势。
静态链接优点:
#pragma comment(lib, "test.lib") ,静态链接的时候,载入代码就会把程序会用到的动态代码或动态代码的地址确定下来静态库的链接可以使用静态链接,动态链接库也可以使用这种方法链接导入库。
静态链接较易被搜索引擎蜘蛛抓取。
动态链接优点:
LoadLibrary()/GetProcessAddress()和FreeLibrary(),使用这种方式的程序并不在一开始就完成动态链接,而是直到真正调用动态库代码时,载入程序才计算(被调用的那部分)动态代码的逻辑地址。然后等到某个时候,程序又需要调用另外某块动态代码时,载入程序又去计算这部分代码的逻辑地址。
这种方式使程序初始化时间较短,但运行期间的性能比不上静态链接的程序。
深度剖析可见:https://blog.csdn.net/wqfhenanxc/article/details/80496522
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)