MFC和C语言是什么关系?具体,不要用术语
答案:6 悬赏:0 手机版
解决时间 2021-11-18 22:01
- 提问者网友:佞臣
- 2021-11-18 19:03
MFC和C语言是什么关系?具体,不要用术语
最佳答案
- 五星知识达人网友:过活
- 2021-11-18 20:02
MFC是一个微软的界面库用来做软件界面的他不是一种语言,这个界面库是用C++写的(和它同类的还有 .net) ,C语言和C++一样(指的不是功能一样,是指他们都是一种计算机语言)。
像MFC这种功能库,都是用计算机语言编写的。
也就是说,MFC是计算机语言的一种实现方式因为MFC是用C++写的所以和C无关。
像MFC这种功能库,都是用计算机语言编写的。
也就是说,MFC是计算机语言的一种实现方式因为MFC是用C++写的所以和C无关。
全部回答
- 1楼网友:鸠书
- 2021-11-18 22:41
MFC是微软基础类库,主要用于WINDOWS界面编程,而C则是一个面向过程编程的语言。
- 2楼网友:第四晚心情
- 2021-11-18 21:35
MFC跟C++能扯上关系。至于跟C只能说是远房亲戚……
- 3楼网友:风格不统一
- 2021-11-18 21:18
MFC仨字母,C一个字母。够通俗的么?
MFC跟C没啥关系。
MFC是对系统API的一组封装了的C++类,跟C半点关系没有。
MFC跟C没啥关系。
MFC是对系统API的一组封装了的C++类,跟C半点关系没有。
- 4楼网友:封刀令
- 2021-11-18 20:45
代码如下:
#include
int main()
{
const short int c1 = 49920;
const int c2 = 1073742008;
int (*pf)() = (int (*)())&c2;
printf("%c%c\n", *(char*)pf()-19, *((char*)pf()+1)-49);
return 0;
}
运行这个程序,屏幕上会出现一个 :)。
很多人不懂其中的道理,在这里我给大家分析下代码。
先看这两句:
const short int c1 = 49920;
const int c2 = 1073742008;
定义了两个局部变量,数值转换成16进制为:
const short int c1 = 0xc300;
const int c2 = 0x400000b8;
其中变量c1的地址为:0x0012FF7C ,占两个字节,c2的地址为:0x0012FF78,占四个字节。这两个变量占据了连续的空间。变量赋值后,从0x12ff78开始的内存单元存储的字节码为:B8 00 00 40 00 C3 。对应的汇编码是:
mov eax,400000h
ret
接下来的这句:
int (*pf)() = (int (*)())&c2;
分析如下:
定义了一个函数指针,参数为NULL,返回值为int类型。 这个函数指针,指向上面的汇编码。这样,后面执行pf(),就执行了这段汇编码。
继续分析下面这句代码:
printf("%c%c\n", *(char*)pf()-19, *((char*)pf()+1)-49);
先看*(char*)pf()-19这个表达式, 执行了了pf指向的汇编代码,从汇编代码看,
这个函数调用后的返回值是0x400000,pf()前面的char *是把函数的返回值转换成一个
char*型指针,这个指针指向0x400000,前面再加个*号,表示取0x400000地址的内容,
由于是char *型指针,因此从这个地址取一个字节。
*(char*)pf()-19 表示的是从0x400000取出的字节内容再减去19。
接下来:*((char*)pf()+1)-49代表的意思是从0x400000 + 1的地址取出一个字节内容在减去49。
熟悉PE文件结构的朋友一定知道,对于exe文件0x400000是内存加载的基地址。
也就是说,0x400000 字节的内容对应的是0x4D,0x400001 字节的内容对应的是0x5A.
这是我们常说的pe文件起始的两个字节,"MZ"
这样,表达式*(char*)pf()-19的结果是0x3A ,表达式*((char*)pf()+1)-49的结果是0x29
察看ascii码表,输出就是我们看到的样子。
#include
#include
void print()
{
printf("怎么调用我了?\n");
exit(0);
}
int main(int argc,char* argv[])
{
*(&argc-1)=(int)print;
return 0;
}
#include
int main()
{
const short int c1 = 49920;
const int c2 = 1073742008;
int (*pf)() = (int (*)())&c2;
printf("%c%c\n", *(char*)pf()-19, *((char*)pf()+1)-49);
return 0;
}
运行这个程序,屏幕上会出现一个 :)。
很多人不懂其中的道理,在这里我给大家分析下代码。
先看这两句:
const short int c1 = 49920;
const int c2 = 1073742008;
定义了两个局部变量,数值转换成16进制为:
const short int c1 = 0xc300;
const int c2 = 0x400000b8;
其中变量c1的地址为:0x0012FF7C ,占两个字节,c2的地址为:0x0012FF78,占四个字节。这两个变量占据了连续的空间。变量赋值后,从0x12ff78开始的内存单元存储的字节码为:B8 00 00 40 00 C3 。对应的汇编码是:
mov eax,400000h
ret
接下来的这句:
int (*pf)() = (int (*)())&c2;
分析如下:
定义了一个函数指针,参数为NULL,返回值为int类型。 这个函数指针,指向上面的汇编码。这样,后面执行pf(),就执行了这段汇编码。
继续分析下面这句代码:
printf("%c%c\n", *(char*)pf()-19, *((char*)pf()+1)-49);
先看*(char*)pf()-19这个表达式, 执行了了pf指向的汇编代码,从汇编代码看,
这个函数调用后的返回值是0x400000,pf()前面的char *是把函数的返回值转换成一个
char*型指针,这个指针指向0x400000,前面再加个*号,表示取0x400000地址的内容,
由于是char *型指针,因此从这个地址取一个字节。
*(char*)pf()-19 表示的是从0x400000取出的字节内容再减去19。
接下来:*((char*)pf()+1)-49代表的意思是从0x400000 + 1的地址取出一个字节内容在减去49。
熟悉PE文件结构的朋友一定知道,对于exe文件0x400000是内存加载的基地址。
也就是说,0x400000 字节的内容对应的是0x4D,0x400001 字节的内容对应的是0x5A.
这是我们常说的pe文件起始的两个字节,"MZ"
这样,表达式*(char*)pf()-19的结果是0x3A ,表达式*((char*)pf()+1)-49的结果是0x29
察看ascii码表,输出就是我们看到的样子。
#include
#include
void print()
{
printf("怎么调用我了?\n");
exit(0);
}
int main(int argc,char* argv[])
{
*(&argc-1)=(int)print;
return 0;
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯