VC++ 设置网卡接口MTU大小

2024-03-15 22:12
文章标签 c++ 接口 设置 大小 网卡 mtu

本文主要是介绍VC++ 设置网卡接口MTU大小,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Windows C/C++ 之中一共有三种方法可以设置网卡的MTU大小。

方法一:

SetIpInterfaceEntry 法

            static bool SetInterfaceMtu2(int interface_index, int mtu) noexcept{PIP_ADAPTER_ADDRESSES pAddresses = NULL;ULONG ulBufLen = 0;GetAdaptersAddresses(AF_UNSPEC, 0, NULL, pAddresses, &ulBufLen);char* szBuf = (char*)Malloc(ulBufLen);pAddresses = (IP_ADAPTER_ADDRESSES*)szBuf;if (NULL == pAddresses){return false;}NETIOAPI_API dwErr = GetAdaptersAddresses(AF_INET, GAA_FLAG_SKIP_ANYCAST, NULL, pAddresses, &ulBufLen);if (dwErr == NO_ERROR){while (NULL != pAddresses){if (pAddresses->IfIndex == interface_index) {MIB_IPINTERFACE_ROW ifRow;InitializeIpInterfaceEntry(&ifRow);//interested nameifRow.InterfaceLuid = pAddresses->Luid;ifRow.Family = AF_INET;ifRow.NlMtu = mtu;dwErr = SetIpInterfaceEntry(&ifRow);break;}pAddresses = pAddresses->Next;}}Mfree(szBuf);return dwErr == NO_ERROR;}

方法二:

SetIfEntry 法

            std::shared_ptr<MIB_IFROW> GetIfEntry(int interface_index) noexcept{if (interface_index < 0){return NULL;}std::shared_ptr<MIB_IFROW> pIfRow = std::shared_ptr<MIB_IFROW>((MIB_IFROW*)Malloc(sizeof(MIB_IFROW)),[](MIB_IFROW* p) noexcept{Mfree(p);});if (NULL == pIfRow){return NULL;}pIfRow->dwIndex = interface_index;if (::GetIfEntry(pIfRow.get()) != NO_ERROR){return NULL;}return pIfRow;}int GetInterfaceMtu(int interface_index) noexcept{std::shared_ptr<MIB_IFROW> ifRow = GetIfEntry(interface_index);if (NULL == ifRow){return -1;}else{return ifRow->dwMtu;}}bool SetInterfaceMtu(int interface_index, int mtu) noexcept{// https://learn.microsoft.com/en-us/windows/win32/api/netioapi/nf-netioapi-getifentry2// https://learn.microsoft.com/en-us/windows/win32/api/iphlpapi/nf-iphlpapi-getifentrystd::shared_ptr<MIB_IFROW> ifRow = GetIfEntry(interface_index);if (NULL == ifRow){return false;}if (ifRow->dwMtu == mtu){return true;}else{ifRow->dwMtu = mtu;}DWORD dwErr = SetIfEntry(ifRow.get());if (dwErr == NO_ERROR){if (GetInterfaceMtu(interface_index) == mtu){return true;}}return SetInterfaceMtu2(interface_index, mtu);}

方法三:

命令行法

查看网络接口设置(MTU列项)

netsh interface ipv4 show subinterfaces

通过网络接口索引来管理,MTU是大小,10为网络接口索引

 netsh interface ipv4 set subinterface 10 mtu=1400 store=persistent

通过网络接口名字来管理,MTU是大小,eth0为网络接口名

netsh interface ipv4 set subinterface eth0 mtu=1400 store=persistent

这篇关于VC++ 设置网卡接口MTU大小的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813423

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

SQL Server 查询数据库及数据文件大小的方法

《SQLServer查询数据库及数据文件大小的方法》文章介绍了查询数据库大小的SQL方法及存储过程实现,涵盖当前数据库、所有数据库的总大小及文件明细,本文结合实例代码给大家介绍的非常详细,感兴趣的... 目录1. 直接使用SQL1.1 查询当前数据库大小1.2 查询所有数据库的大小1.3 查询每个数据库的详

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

基于Redisson实现分布式系统下的接口限流

《基于Redisson实现分布式系统下的接口限流》在高并发场景下,接口限流是保障系统稳定性的重要手段,本文将介绍利用Redisson结合Redis实现分布式环境下的接口限流,具有一定的参考价值,感兴趣... 目录分布式限流的核心挑战基于 Redisson 的分布式限流设计思路实现步骤引入依赖定义限流注解实现