我有一个列向量A,长度为10个元素.我有一个10乘10的矩阵B.B的内存存储是列专业.我想用列向量A 覆盖B中的第一行.
显然,我可以这样做:
for ( int i=0; i < 10; i++ )
{
B[0 + 10 * i] = A[i];
}
Run Code Online (Sandbox Code Playgroud)
我把零放在0 + 10 * i一边突出显示B使用列主存储(零是行索引).
在今晚CUDA-land的一些恶作剧之后,我想到可能有一个CPU功能来执行一个跨步的memcpy?我想在低级别,性能将取决于是否存在一个跨步加载/存储指令,我不记得在x86汇编中?
简短的回答:你写的代码和它的代码一样快.
答案memcpy很长:该函数是使用一些复杂的内在函数或汇编编写的,因为它在具有任意大小和对齐的内存操作数上运行.如果你要覆盖矩阵的一列,那么你的操作数将具有自然对齐,你不需要采用相同的技巧来获得合适的速度.