StackTc 2018-05-26 17:21 采纳率: 90.9%
浏览 777
已结题

数组都clone问题,求解释

最近看一本书叫《改善java程序的151个建议》,发现这么一个方法。

 public static int max(int[] data) {
        Arrays.sort(data.clone()); //秒处
        return data[data.length - 1]
 }

这个方法的意图是找到数组中最大的一个数,为什么排序的是克隆对象呢,
因为这个方法的目的是取最大数,通过克隆对象去取的话,不改变原有数组的结构,
可是读者发现这个方法有问题,排序的是克隆对象,取值却还是从原来的数组中取.
请教大家,这个方法应该到底怎么写。

  • 写回答

5条回答 默认 最新

  • 默默悟问 2018-05-26 17:34
    关注
         public static int max(int[] data) {
             int[] newData = data.clone();
         Arrays.sort(newData);
         return newData[newData.length - 1];
         }
    

    这是没效率的方法,不是反面教材?

    评论

报告相同问题?

悬赏问题

  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘