如何for loops
使用C ++ 17功能优雅地简化(或消除)下面的代码?
#pragma pack(push, 1)
typedef struct ethernet_frame
{
unsigned char dst[6];
unsigned char src[6];
unsigned short proto;
} ethernet_frame, *ethernet_frame_ptr;
#pragma pack(pop)
int i;
ethernet_frame eFrame = { {00,00,00,00,00,00}, {42, 54, 33, 67, 14, 88}, 0x800 };
ProcessFrame(&eFrame); //A library function expecting an address of an ethernet_frame with its strict bit layout
i = 0;
for (unsigned char c : { 36, 84, 23, 77, 35, 11 }) eFrame.dst[i++] = c;
ProcessFrame(&eFrame);
i = 0;
for (unsigned char c : { 65, 23, 74, 82, 20, 94 }) eFrame.dst[i++] = c;
ProcessFrame(&eFrame);
i = 0;
for (unsigned char c : { 47, 22, 86, 45, 33, 38 }) eFrame.dst[i++] = c;
ProcessFrame(&eFrame);
// etc...
像eFrame.Dst = { 47, 22, 86, 45, 33, 38 }
这样的重新分配会很整洁...但是它们是非法的:(
如果您不能更改struct ethernet_frame
为use std::array
,那么仍然可以使用几个单行来复制数据,尽管不太安全。首先,使用好old memcpy()
:
#include <cstring>
...
memcpy(eFrame.dst, std::array<unsigned char, 6>{36, 84, 23, 77, 35, 11}.begin(), std::size(eFrame.dst));
或使用std::copy_n()
:
#include <algorithm>
...
std::copy_n(std::array<unsigned char, 6>{36, 84, 23, 77, 35, 11}.begin(), std::size(eFrame.dst), eFrame.dst);
使用Ranges TS,您可以避免必须指定要复制的数据大小:
#include <experimental/ranges/algorithm>
...
std::experimental::ranges::copy(std::array<unsigned char, 6>{36, 84, 23, 77, 35, 11}, eFrame.dst);
另外,如果没有一个衬里要使用多个对象,那么您当然可以总是自己编写一个函数,将问题变成一个衬里。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句