q=L.elem+L.length-1和q=&L.elem[L.length-1]为什么一样?L.elem是什么意思?
2个回答
推荐于2020-01-25
展开全部
L.elem是地址,是基址 L.elem+L.length-1是最后一个元素的地址
L.elem[i]是第i个元素
&L.elem[i]是第i个元素的地址
同理&L.elem[L.length-1]是最后一个元素的地址
纯手工打造 忘采纳
L.elem[i]是第i个元素
&L.elem[i]是第i个元素的地址
同理&L.elem[L.length-1]是最后一个元素的地址
纯手工打造 忘采纳
展开全部
没有上下文,不太好说
但这里的L.elem是个某个数据类型指针或数组,拿数据类型char举个例子
struct LS
{
char* elem;
unsigned int length;
};
q = L.elem+L.length-1和q=&L.elem[L.length-1]都是指向elem最后一个char元素的指针
所以它们一样
int main(){
LS L;
L.length = 10;
L.elem = new char[L.length];
char* p = L.elem + L.length - 1;
char* q = &L.elem[L.length-1];
if( p == q )
printf( "==\n" );
else
printf( "!=\n" );
return 0;
}
但这里的L.elem是个某个数据类型指针或数组,拿数据类型char举个例子
struct LS
{
char* elem;
unsigned int length;
};
q = L.elem+L.length-1和q=&L.elem[L.length-1]都是指向elem最后一个char元素的指针
所以它们一样
int main(){
LS L;
L.length = 10;
L.elem = new char[L.length];
char* p = L.elem + L.length - 1;
char* q = &L.elem[L.length-1];
if( p == q )
printf( "==\n" );
else
printf( "!=\n" );
return 0;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询