目录
简介
求职策略分为严格的和非严格的。
严格求值又分为传值、传共享对象(传地址)、引用。
- 传值不可以改变实参的值。
- 传共享对象可以改变实参的值。
- 传引用可以改变实参的值。
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 <iostream> struct Teacher { int &a; int &b; }; int main() { printf("sizeof(Teacher) %d\n", 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只有值传递。