java-关于形参和实参问题,,,,,

问题描述

关于形参和实参问题,,,,,

1.我将实参传递给形参,实参会随着形参改变而改变吗?
2.将实参传递给形参,该方法在多线程里启动。这样我若实参改变,线程里的形参变吗?
3.以上的问题,基于基本类型和非基本类型都一样吗??
记得基本类型不是值传递,实体类是引用传递。。。
糊涂了。求助

解决方案

1,如果你传递的是值的话,变量的值不会变,如果你传递的是引用的话(相当于地址),地址指向的内容就会改变
2,道理一样
3,非基本类型会改变吧,比如你传递字符串,改变实参的值,形参也会改变

解决方案二:

形参和实参
c++形参实参
什么是形参和实参?

解决方案三:

前面两个问题都是一样的,传引用就会变(比如数组,对象,等),如果你传递int,实参就不会发生变化。

第三个问题,基本类型和非基本类型是不一样的,基本类型和对象的引用都放在栈中,new出的对象和数组放在堆中

时间: 2024-10-22 06:42:12

java-关于形参和实参问题,,,,,的相关文章

c语言-此程序为何当选择1的时候没有矩阵输出,好像是形参与实参的关系错了,求解释,求改正。

问题描述 此程序为何当选择1的时候没有矩阵输出,好像是形参与实参的关系错了,求解释,求改正. // juzhen 2.cpp : Defines the entry point for the console application. // #include "stdafx.h" #include "stdlib.h" typedef struct mat { int nRow; /* 行数 / int nCol; / 列数 / int pData; /* 指向矩?

我想用指针作为函数形参,实参为数组 实现数组元素反序存放。可是只能交换前五个

问题描述 我想用指针作为函数形参,实参为数组 实现数组元素反序存放.可是只能交换前五个 #include using namespace std; void invert(int A,int); int main() { int A[10],n; cout<<"Please input 10 number:"< for(n=0;n cin>>A[n]; invert(A,10); return 0; } void invert(int *A,int n)

C++形参与实参的区别实例解析_C 语言

本文以实例阐述了C++中形参与实参的区别,有助于读者加深对于C++形参与实参的认识. 形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用.实参出现在主调函数中,进入被调函数后,实参变量也不能使用. 形参和实参的功能是作数据传送.发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送. 1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元.因此,形参只有在函数内部有效. 函数调用结束返回主调函数后则不能再使用该

《像计算机科学家一样思考Python》——3.8 形参和实参

3.8 形参和实参 我们已经看到,有些内置函数需要传入参数.比如,当调用math.sin时,需要传入一个数字作为实参.有的函数需要多个实参:math.pow需要两个,分别是基数(base)和指数(exponent). 在函数内部,实参会被赋值给形参.下面的例子是一个用户自定义的函数,接收一个实参: def print_twice(bruce): print bruce print bruce 这个函数在调用时会把实参的值赋到形参bruce上,并将其打印两次. 这个函数对任何可以打印的值都可用.

php中函数的形参与实参的问题说明_php技巧

当实参个数<形参个数 时php会发出警告,因为php的解释机制会认为,有参数被定义了却没有被使用,那很可能会影响函数的功能.所以会发出警告.然而,当 实参个数>形参个数 时,php是不会报错的,它只会取前面的几个参数,多余的则将会丢弃. 在PHP中编写函数,一般情况下调用函数的时候,改变的值都是形参而不是实参.但是如果在形参中加入地址符时候就会改变实参的值,为什么? 请看下面的例子: 复制代码 代码如下: <?php //编写一个函数swap(),测试该函数的实参值无改变 functio

const形参和实参

当形参是const时,必须要注意关于顶层const的讨论.如前所述,顶层const的作用于对象本身: const int ci=42;  //不能改变ci,const是顶层的 int i=ci:   //正确:当拷贝ci时,忽略了它的顶层const int *const p=&i;  //const是顶层的,不能给p赋值 *p=0;    //正确:通过p改变对象的内容是允许的,现在i变成了0 和其他初始化过程一样,当用实参初始化形参时会忽略掉顶层const.换句话说,形参的顶层const被忽略

函数中指针和引用的形参和实参

#include <iostream> using namespace std; void change(int *a,int &b,int c)//指针作形参,前面加*号,引用作形参前面加&号. { c=*a; b=3; *a=2; } int main() { int a=1,b=2,c=3; change(&a,b,c);//指针作实参,前面加取地址符&,引用作实参,前面不加符号 cout<< a<< b<< c<

参数识别-java小白又来提问啦,形参实参的辨别。

问题描述 java小白又来提问啦,形参实参的辨别. 代码如下: public class Test { public static void main(String[] args){ int max= 0; max(1,2,max);//此处括号里的1,2,max是实参 System.out.println(max);//这个语句里的max也是实参,这个理解是否正确? } public static void max(int n1,int n2,int max){//方法签名里的max是形参 i

java 实参和形参的区别

打个比方:方法就像城门,而形参则规定了什么人可以通过(对方法来说就是调用).城门张贴了通行规定:1.男性能通过,女性不可以(类似于条件1)2.必须是活人(死人类似于方法中传入null).根据此规定,如果是活的男人的话,无论是大人小孩青年老人病人.爷爷儿子孙子兄弟都可以进入此门(甚至公狗也可以),任何非男性生物均不能通过.反应到方法上来,比如有这样一个方法:public void doSometing(Object obj),Object相当于所有物体,在方法中进行判断此物体是否为雄性类似于张贴通