C/C++里二维数组传参时需要指定每行有几个元素(第二维长度),具体有三种常见的写法:
// 参数传int a[][]过不了类型检查
void foo1(int a[][2]) {
a[1][1] = 10;
}
void foo2(int *a[2]) {
a[1][1] = 10;
}
void foo3(int **a) {
a[1][1] = 10;
// 等价的寻址写法
// *(*(a+1)+1) = 10;
}
这三种写法在传参的性能上没有区别,在64位机器上都是传了8 bytes的指针,可以在 Compiler Explorer 上在线查看对应的汇编代码:
foo1(int (*) [2]):
push rbp
mov rbp, rsp
mov QWORD PTR [rbp-8], rdi
mov rax, QWORD PTR [rbp-8]
add rax, 8
mov DWORD PTR [rax+4], 10
nop
pop rbp
ret
foo2(int**):
push rbp
mov rbp, rsp
mov QWORD PTR [rbp-8], rdi
mov rax, QWORD PTR [rbp-8]
add rax, 8
mov r