从冒泡排序法中看java的数据传递机制

系统 1597 0
    在java中,数据分为基本数据和引用型数据(也就是用new关键字创建的),java对这两种数据的传递的方式是不一样的,对于基本数据是传值而对于引用型数据则传递的是数据的引用.
一个整形的数组我们用冒泡排序法进行排序,以下是两种示例代码:

第一种:
    
public class BubbleSort {
		public static void main(String[] args) {
				int[] arr ={4,6,2,7,3,1,5,8};
				int n = arr.length;
				for(int i = 0; i < n;i++) {
						for(int j = 0; j < n-1-i;j++) {
								if(arr[j]>arr[j+1]) {
										swap(arr,j,j+1);
								}	
						}	
				}
				for(int i = 0; i < arr.length; i++)
						System.out.print(arr[i] + " ");
		}	
		public static void swap(int[] arr, int i,int j) {
				int term = arr[i];
				arr[i] = arr[j];
				arr[j] = term;	
		}
}

  


第二种:
    
public class BubbleSort {
		public static void main(String[] args) {
				int[] arr ={4,6,2,7,3,1,5,8};
				int n = arr.length;
				for(int i = 0; i < n;i++) {
						for(int j = 0; j < n-1-i;j++) {
								if(arr[j]>arr[j+1]) {
										swap(arr[j],arr[j+1]);
								}	
						}	
				}
				for(int i = 0; i < arr.length; i++)
						System.out.print(arr[i] + " ");
		}	
		public static void swap(int i,int j) {
				int term = i;
				i = j;
				j = term;	
		}
}


  


    经过测试我们发现第一种方法正确,而第二种的结果不是我们想要的.经过代码的分析我们发现两者的唯一区别是交换方法不一样.
第二种的swap方法中传入的是两个基本数据,而第一种则传入了数组,这个引用型的数据.也就是说,第二种传入的是数据的值,把原来的值复制了一份给了swap,而当这个访求结束后,虽然发生了交换,但不是原来的数据发生了交换,而是其复制品.而第一种传入了数组,由于数组是一个引用型的变量.它传给swap方法的是数组的引用,而不是具体的值,这样它与原来的引用都是指向heap里的同一个数据,因此对这个引用的操作会直接影响到原来的数据.因此第一种会出现我们想要的结果.






从冒泡排序法中看java的数据传递机制


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论