c++按值传递、引用传递及指针传递的理解

本文通过实例详细解析了C++中三种参数传递方式:值传递、引用传递和指针传递的区别与应用场合。值传递不会改变原变量值,适合不需要修改的情况;引用和指针传递能直接修改原变量值,适用于需要修改的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

举个栗子,分析一下C++按值传递、引用传递和指针传递的区别:

#include "transmit.h"
#include <iostream>

using namespace std;

//按值传参
void changeValue(int x)
{
	x = x + 5;
	cout << "地址是:" << &x;
	cout << " 值是:" << x << endl;
}

//按引用
void changeValueq(int &x)
{
	x = x + 8;
	cout << "地址是:" << &x;
	cout << " 值是:" << x << endl;
}

//按指针
void changeValuep(int *x)
{
	*x = *x + 10;
	cout << "地址是:" << x;
	cout << " 值是:" << *x << endl;
}

int main()
{
	int x = 10;
	cout << "原地址是:" << &x << endl;

	cout << "按值传递:";
	changeValue(x);
	
	cout << "按引用传递:";
	changeValueq(x);

	cout << "按指针传递:";
	changeValuep(&x);


	return 0;
}

输出以下结果:

结论:

由结果看到,按值传递时,x的地址发生了变化。但是按指针和引用传递地址都没有变化。

a、当函数内部需要修改变量的值,又不希望修改后影响变量值时,采用值传递。

b、引用是变量的别名,对引用的操作就是对变量的操作。所以改变了引用的值,变量x的值也会改变。

c、指针存放的是变量的地址,对指针操作,就相当于对变量进行操作。

所以按引用传递和按指针传递都能改变变量的值。

在实现 MUI 底部选项卡的跳转功能时,可以使用 `<BottomNavigation>` 和 `<BottomNavigationAction>` 组件来创建底部导航栏和选项卡。 首先,你需要导入相关的组件: ```jsx import React, { useState } from 'react'; import { BottomNavigation, BottomNavigationAction } from '@mui/material'; import { Home, Explore, Favorite } from '@mui/icons-material'; ``` 然后,你可以创建一个函数组件,并在组件中添加底部导航栏和选项卡的代码: ```jsx function BottomTabs() { const [value, setValue] = useState(0); // 用于保存当前选中的选项卡索引 const handleTabChange = (event, newValue) => { setValue(newValue); // 更新选中的选项卡索引 }; return ( <BottomNavigation value={value} onChange={handleTabChange}> <BottomNavigationAction label="Home" icon={<Home />} /> <BottomNavigationAction label="Explore" icon={<Explore />} /> <BottomNavigationAction label="Favorite" icon={<Favorite />} /> </BottomNavigation> ); } ``` 在上面的代码中,我们使用 `useState` 钩子来创建一个名为 `value` 的状态变量,用于保存当前选中的选项卡索引。`handleTabChange` 函数用于处理选项卡变动事件,并更新 `value` 的值。 最后,将 `BottomTabs` 组件添加到你的页面中即可: ```jsx function App() { return ( <div> {/* 其他内容 */} <BottomTabs /> </div> ); } ``` 这样,你就实现了 MUI 底部选项卡的跳转功能。当用户点击不同的选项卡时,会触发 `handleTabChange` 函数,并更新 `value` 的值,从而实现页面的跳转效果。你可以根据自己的需求,在每个选项卡的 `onClick` 事件中添加相应的跳转逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值