C一文详解中的关键点有哪些?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1395个文字,预计阅读时间需要6分钟。
目录一:为什么C++不支持+二:C+++符号表示突破三:C
目录
- 一:为什么 C 不支持
- 二:C++ 符号表突破
- 三:C#如何实现突破
最近在看 C++ 的方法重载,我就在想 C# 中的重载底层是怎么玩的,很多朋友应该知道 C 是不支持重载的,比如下面的代码就会报错。
#include <stdio.h> int say() { return 1; } int say(int i) { return i; } int main() { say(10); return 0; }
从错误信息看,它说say方法已经存在了,尴尬。。。
一:为什么 C 不支持
要想寻找答案,需要了解一点点底层知识,那就是编译器在编译 C 方法时会将函数名作为符号添加到符号表中,这个符号表就是call到say方法字节码中间的一个载体,画个图大概就是这样。
简而言之,call 先跳转到符号表, 然后再 jmp 到 say 方法,问题就出现在这里,符号表是一种类字典结构,是不可以出现符号相同的情况。
本文共计1395个文字,预计阅读时间需要6分钟。
目录一:为什么C++不支持+二:C+++符号表示突破三:C
目录
- 一:为什么 C 不支持
- 二:C++ 符号表突破
- 三:C#如何实现突破
最近在看 C++ 的方法重载,我就在想 C# 中的重载底层是怎么玩的,很多朋友应该知道 C 是不支持重载的,比如下面的代码就会报错。
#include <stdio.h> int say() { return 1; } int say(int i) { return i; } int main() { say(10); return 0; }
从错误信息看,它说say方法已经存在了,尴尬。。。
一:为什么 C 不支持
要想寻找答案,需要了解一点点底层知识,那就是编译器在编译 C 方法时会将函数名作为符号添加到符号表中,这个符号表就是call到say方法字节码中间的一个载体,画个图大概就是这样。
简而言之,call 先跳转到符号表, 然后再 jmp 到 say 方法,问题就出现在这里,符号表是一种类字典结构,是不可以出现符号相同的情况。

