简介
求职策略分为严格的和非严格的。
严格求值又分为传值、传共享对象(传地址)、引用。
![5b9ac8a5faa2f3a1863beef072b28d9e.png](https://i-blog.csdnimg.cn/blog_migrate/13853c55405676e91c08531be79e63da.jpeg)
传值不可以实参的值。
传共享对象可以改变实参的值。
传引用可以改变实参的值。
c语言
c语言中只有传值和传地址(使用指针)。
但是传地址实际上也是传值,只不过传递的值是地址。所以传地址是传值的特例。
c++
传值方式
c++中有传值、传地址、传引用。
传值和传地址和c语言相同。
引用
详解引用
首先明确几个概念然后我再解释着几个概念
引用在c++中的内部实现是一个常指针。
引用所占用的空间大小与指针相同。
从使用的角度,引用会让人误会其只是一个别名,没有自己的存储空间。这是C++为了实用性而做出的细节隐藏。
对上述概念的实例解释
解释(1):fun3中指针a的指向可以改变,而fun1和fun2中a的指向无法改变,所以可以看出引用在c++中的内部实现是一个常指针。
void func1(int &a)
{
a = 5;
}
void func2(int *const a)
{
*a = 5;
}
void func3(int *a)
{
*a = 5;
}
int main()
{
int x = 10;
func1(x);
return 0;
}
解释(2):运行一下程序结果为:sizeof(Teacher) 8,所以说引用所占用的空间大小与指针相同。
#include
struct Teacher {
int &a;
int &b;
};
int main()
{
printf("sizeof(Teacher) %d", sizeof(Teacher));
return 0;
}
引用总结
间接赋值的3个必要条件
1定义两个变量 (一个实参一个形参)
2建立关联 实参取地址传给形参
3*p形参去间接的修改实参的值
引用在实现上,只不过是把间接赋值成立的三个条件的后两步和二为一。当实参传给形参引用的时候,只不过是c++编译器帮我们程序员手工取了一个实参地址,传给了形参引用(常量指针)。
java
java中只有值传递(细分为值传递和地址传递,因为前面c语言中已经说了地址传递是值传递的一种特例)
为什么只有值传递?
首先基本数据类型只有值传递这是毋庸置疑的。
其次我们来讨论(java中的)对象的传递
java中对象的传递类似于c语言和c++语言中传地址(利用指针)
证明:
当代码为下面形式时
public static void main(String[] args) {
Test pt = new Test();
User hollis = new User();
hollis.setName("Hollis");
hollis.setGender("Male");
pt.pass(hollis);
System.out.println("print in main , user is " + hollis);
}
public void pass(User user) {
user.setName("hollischuang");
System.out.println("print in pass , user is " + user);
}
输出结果:
print in pass , user is User{name='hollischuang', gender='Male'}
print in main , user is User{name='hollischuang', gender='Male'}
但是当代码改为下面形式时:
public void pass(User user) {
user = new User();
user.setName("hollischuang");
System.out.println("print in pass , user is " + user);
}
输出结果:
print in pass , user is User{name='hollischuang', gender='Male'}
print in main , user is User{name='Hollis', gender='Male'}
所以user = new User()语句相当于c和c++中非const指针指向新的地址。所以说java中对象的传递类似于c语言和c++语言中传地址(利用指针)。所以说java只有值传递。