360、腾讯、迅雷Windows编程、网络编程面试题及答案

简介: MainFrm为框架类,包含应用程序外框所包含部分。CView为视图类,用于显示数据的空白区域窗口。CDocument为文档类。MFC提供了文档/视类结构,采用数据本身和显示分离的机制。其中文档类CDocument用于数据的存储和加载,视类CView用于数据的显示与修改。

1`. 问MainFrm,CDocument和CView类之间的关系,


MainFrm为框架类,包含应用程序外框所包含部分。CView为视图类,用于显示数据的空白区域窗口。


CDocument为文档类。


MFC提供了文档/视类结构,采用数据本身和显示分离的机制。其中文档类CDocument用于数据的存储和加载,视类CView用于数据的显示与修改。


2. Dialog和 ModuelDialog不同用法


1)类型不同


MoudleDialog 模态对话框,属于垄断对话框,例如打开对话框,点击打开后不能再执行其他操作,会发出“嘟嘟嘟”的声音;


      非模态对话框,属于非垄断对话框,利用查找对话框,点击查找同时可以执行其他操作;


      即:非模态不垄断;模态垄断。


2)用法不同


      CDialog::Create :to create a modelessdialog box


      CDialog::DoModal :Call this member function to invoke the modal dialog box andreturn the dialog-box result when done


3. 网络编程的一般步骤


对于TCP连接:


1.服务器端1)创建套接字create;2)绑定端口号bind;3)监听连接listen;4)接受连接请求accept,并返回新的套接字;5)用新返回的套接字recv/send;6)关闭套接字。


2.客户端1)创建套接字create; 2)发起建立连接请求connect; 3)发送/接收数据send/recv;4)关闭套接字。


TCP总结:


Server端:create -- bind -- listen--  accept--  recv/send-- close


Client端:create------- conncet------send/recv------close.




对于UDP连接:


1.服务器端:1)创建套接字create;2)绑定端口号bind;3)接收/发送消息recvfrom/sendto;4)关闭套接字。


2.客户端:1)创建套接字create;2)发送/接收消息sendto/recvfrom;3)关闭套接字.


UDP总结:


Server端:create----bind ----recvfrom/sendto----close


Client端:create----  sendto/recvfrom----close.




4.sendMessage与postMessage区别?


不同点:sendMessage发送完毕以后需要等待处理完才返回;而postMessage发送消息后立即返回。


Do not post the WM_QUIT message using PostMessage; use thePostQuitMessage function.


postMessage将消息放置到消息队列中,不等待线程处理消息就立即返回。


sendMessage发送指定的消息到窗口,并会调用窗口过程,直到窗口过程处理完毕后才返回。



5. TCP的重发机制是怎么实现的?


      1.滑动窗口机制,确立收发的边界,能让发送方知道已经发送了多少(已确认)、尚未确认的字节数、尚待发送的字节数;让接收方知道(已经确认收到的字节数)。


      2.选择重传,用于对传输出错的序列进行重传。


6. TCP和UDP的区别?


      1)TCP面向连接(三次握手机制),通信前需要先建立连接;UDP面向无连接,通信前不需要建立连接;


      2)TCP保障可靠传输(按序、无差错、不丢失、不重复);UDP不保障可靠传输,使用最大努力交付;


      3)TCP面向字节流的传输,UDP面向数据报的传输。


7.进程间通信有哪些方式?


      1)共享内存,如剪贴板;


      2)匿名管道/命名管道;


      3)邮槽。


      其中共享内存、匿名管道只能实现两个进程间的通信,不能跨网络通信;命名管道和邮槽可以跨网络进程间通信;但命名管道属于点对点的通信,可传输大数据量;而邮槽一次传输的数据量非常有限,通常少于424字节。


8.TCP为什么不是两次连接?而是三次握手?


如果A与B两个进程通信,如果仅是两次连接。可能出现的一种情况就是:A发送完请报文以后,由于网络情况不好,出现了网络拥塞,即B延时很长时间后收到报文,即此时A将此报文认定为失效的报文。B收到报文后,会向A发起连接。此时两次握手完毕,B会认为已经建立了连接可以通信,B会一直等到A发送的连接请求,而A对失效的报文回复自然不会处理。依次会陷入B忙等的僵局,造成资源的浪费。


9. connect方法会阻塞,请问有什么方法可以避免其长时间阻塞?


可以考虑采用异步传输机制,同步传输与异步传输的主要区别在于同步传输中,如果调用recvfrom后会一致阻塞运行,从而导致调用线程暂停运行;异步传输机制则不然,会立即返回。


8.网络编程中设计并发服务器,使用多进程与多线程,请问有什么区别?


答案一:


1,进程:子进程是父进程的复制品。子进程获得父进程数据空间、堆和栈的复制品。


2,线程:相对与进程而言,线程是一个更加接近与执行体的概念,它可以与同进程的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。两者都可以提高程序的并发度,提高程序运行效率和响应时间。


线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源管理和保护;而进程正相反。同时,线程适合于在SMP机器上运行,而进程则可以跨机器迁移。


答案二:


根本区别就一点:用多进程每个进程有自己的地址空间(address space),线程则共享地址空间。所有其它区别都是由此而来的:


1。速度:线程产生的速度快,线程间的通讯快、切换快等,因为他们在同一个地址空间内。


2。资源利用率:线程的资源利用率比较好也是因为他们在同一个地址空间内。


3。同步问题:线程使用公共变量/内存时需要使用同步机制还是因为他们在同一个地址空间内。


等等


9. 简述Windows编程容易出错的几点


      ??


10.Windows编程的知识点,如消息机制,一个自定义消息如何实现。


      自定义消息共分为3步骤:


1)  自定义消息:#defineWM_MYMSG WM_USER+1


2)  在头文件中声明函数:       afx_msg voidonMyMsg();


3) 在消息映射中添加对应关系:


//BEGIN_MESSAGE_MAP(CDefMsgDemoDlg,CDialog) //END_MESSAGE_MAP()


ON_MESSAGE(WM_MYMSG,onMyMsg)


4)定义函数void onMyMsg();


核心即:函数原型、关联消息与消息响应函数的宏、函数实现。



11.SNMP协议


      简单网络管理协议——应用层协议.


      包括5种数据包:Get-Request;Get-Next-Request; Set-Request, Get-Response; Trap;


12.RAW套接字


      广泛应用于高级网络编程,如SNIFFER、拒绝服务、IP欺骗都是通过原始套接字实现的。



13. 窗口创建的步骤:


1)设计窗口类(填充结构体)à2)注册窗口类RegisterClassà3)创建窗口;4)显示ShowWindow&更新窗口UpdateWindowà4)循环获取消息GetMessage(){翻译(转换)TranslateMessage消息、处理消息DispathMessage(将消息交付给窗口过程进行处理)}。



14. 当触发按钮以后发生了什么?


      1)比如点击鼠标左键后,操作系统首先会感知到该事件;2)操作系统将事件其转化为消息;3)操作系统将消息投递到对应程序(线程)的消息队列中;4)应用程序(线程)从消息队列中通过GetMessage获取消息,并通过DispathMessge将消息交付给操作系统;5)操作系统通过设计窗口类时指定的窗口过程对对消息进行处理。



15. 你平时是如何调试程序的?(引申)当一个程序在自己机器上运行正常,但是在其他机器上程序运行崩溃,如何查找原因?


断点调试:


值:查看变量(Variables)、表达式、内存(Memory)、寄存器(Register)的值。


进程控制:VC允许被中断的程序继续运行、单步运行和运行到指定光标处,分别对应快捷键F5、F10/F11和CTRL+F10。


其他调试手段:系统提供一系列特殊的函数或者宏来处理Debug版本相关的信息TRACE、ASSERT、VERIFy。Ctrl+B打开断点设置。


运行崩溃,如何查找原因? [提示后],可以通过打印语句来发现错误!



16.   线程、窗口、消息队列三者之间的关系?


MSDN上如是说:


Thethread to which the message is posted must have created a message queue,or elsethe call to PostThreadMessage fails.  


并提供了如下两种解决方法:


CallPostThreadMessage.If it fails, call the Sleep function and call PostThreadMessageagain. Repeat  until  PostThreadMessage  succeeds.


【面试官】说:一个线程对应一个或多个窗口(创建的关系),同时一个线程对应了一个消息队列。


【总结如下】:

1.在MFC程序框架里面,CWinThread专门负责线程创建的,它可以创建用户界面线程,及工作者线程。其中用户界面线程是包含消息队列的,而工作者线程是不包含消息队列的。即【一句话】:用户界面线程对应一个消息队列。

2.CWinThread类和CWnd类都派生自CCmdTarget,而CDialog对话框类、视图类CView都派生自CWnd。

【深入浅出MFC里一句话】:不是每一个窗口都产生一个线程(因为要付出昂贵的线程切换代价)。即,深入理解之:一个线程可以对应多个窗口。主线程可以创建出其所要的全部窗口。

【结论】一个UI线程就1组消息队列集合,一个线程可以创建多个窗口。


     大家一起探讨下,对不对?欢迎讨论。。。


相关文章
|
17天前
|
网络协议 安全 Java
Java中的网络编程:Socket编程详解
Java中的网络编程:Socket编程详解
|
21天前
|
网络协议 安全 Java
Java中的网络编程:Socket编程详解
Java中的网络编程:Socket编程详解
|
1月前
|
缓存 网络协议 安全
Android网络面试题之Http基础和Http1.0的特点
**HTTP基础:GET和POST关键差异在于参数传递方式(GET在URL,POST在请求体),安全性(POST更安全),数据大小限制(POST无限制,GET有限制),速度(GET较快)及用途(GET用于获取,POST用于提交)。面试中常强调POST的安全性、数据量、数据类型支持及速度。HTTP 1.0引入了POST和HEAD方法,支持多种数据格式和缓存,但每个请求需新建TCP连接。**
29 5
|
28天前
|
安全 网络协议 算法
Android网络基础面试题之HTTPS的工作流程和原理
HTTPS简述 HTTPS基于TCP 443端口,通过CA证书确保服务器身份,使用DH算法协商对称密钥进行加密通信。流程包括TCP握手、证书验证(公钥解密,哈希对比)和数据加密传输(随机数加密,预主密钥,对称加密)。特点是安全但慢,易受特定攻击,且依赖可信的CA。每次请求可能复用Session ID以减少握手。
28 2
|
1月前
|
缓存 JSON 网络协议
Android面试题:App性能优化之电量优化和网络优化
这篇文章讨论了Android应用的电量和网络优化。电量优化涉及Doze和Standby模式,其中应用可能需要通过用户白名单或电池广播来适应限制。Battery Historian和Android Studio的Energy Profile是电量分析工具。建议减少不必要的操作,延迟非关键任务,合并网络请求。网络优化包括HTTPDNS减少DNS解析延迟,Keep-Alive复用连接,HTTP/2实现多路复用,以及使用protobuf和gzip压缩数据。其他策略如使用WebP图像格式,按网络质量提供不同分辨率的图片,以及启用HTTP缓存也是有效手段。
46 9
|
1月前
|
Windows
解决Windows 11/10 上的网络打印机错误 0x0000011b
解决Windows 11/10 上的网络打印机错误 0x0000011b
37 5
|
29天前
|
缓存 网络协议 Android开发
Android网络面试题之Http1.1和Http2.0
HTTP/1.1 引入持久连接和管道机制提升效率,支持分块传输编码和更多请求方式如PUT、PATCH。Host字段指定服务器域名,RANGE用于断点续传。HTTP/2变为二进制协议,实现多工处理,头信息压缩和服务器推送,减少延迟并优化资源加载。HTTP不断发展,从早期的简单传输到后来的高效交互。
26 0
Android网络面试题之Http1.1和Http2.0
|
1月前
|
缓存 网络协议 Java
Android面试题之Java网络通信基础知识
Socket是应用与TCP/IP通信的接口,封装了底层细节。网络通信涉及连接、读写数据。BIO是同步阻塞,NIO支持多路复用(如Selector),AIO在某些平台提供异步非阻塞服务。BIO示例中,服务端用固定线程池处理客户端请求,客户端发起连接并读写数据。NIO的关键是Selector监控多个通道的事件,减少线程消耗。书中推荐《Java网络编程》和《UNIX网络编程》。关注公众号AntDream了解更多。
26 2
|
1月前
|
XML JSON Java
Android面试题 之 网络通信基础面试题
序列化对比:Serializable码流大、性能低;XML人机可读但复杂;JSON轻量、兼容性好但空间消耗大;ProtoBuff高效紧凑。支持大量长连接涉及系统限制调整、缓冲区优化。select/poll/epoll是IO多路复用,epoll在高连接数下性能更优且支持边缘触发。水平触发持续通知数据,边缘触发仅通知新数据。直接内存减少一次拷贝,零拷贝技术如sendfile和MMAP提升效率。关注公众号"AntDream"了解更多技术细节。
20 1
|
1月前
|
移动开发 网络协议 视频直播
25.Python 网络编程:TCP和UDP编程
25.Python 网络编程:TCP和UDP编程
25 2