day&day

 

选择排序

for (int i = 0; i < arr.length-1; i++) {

for (int j = i+1; j < arr.length; j++) {

if (arr[j]>arr[i]) {

arr[j]=arr[i]^arr[j];

arr[i]=arr[j]^arr[i];

arr[j]=arr[i]^arr[j];

}

}

}

 

 

冒泡排序

for (int i = 0; i < arr.length-1; i++) {

for (int j = 0; j < arr.length-1-i; j++) {

if (arr[j]<arr[j+1]) {

arr[j]=arr[j]^arr[j+1];

arr[j+1]=arr[j]^arr[j+1];

arr[j]=arr[j]^arr[j+1];

}

}

}

 

/*
单例设计模式:

懒汉单例设计模式(线程安全问题 的解决方案):
步骤:
1. 私有化构造函数。
2. 声明本类引用类型变量,但是不要创建对象。
3. 声明一个公共静态的方法获取本类的对象,获取之前先判断是否已经创建了本类的对象了,如果已经创建了
就不要在创建直接返回即可,如果还没有创建,那么就先创建本类的引用类型变量,然后再返回。

*/

//懒汉单例设计模式
class Single{

// 声明本类引用类型变量,但是不要创建对象。
private static Single s;

  //私有化构造函数
  private Single(){}

  // 声明一个公共静态的方法获取本类的对象
  public static Single getInstance(){
    if(s==null){
      synchronized ("锁") {
      if(s==null){
      s = new Single();
        }
      }
    }
  return s;
  }

}

 

/*
内存泄露

需求:编写一个类使用数组模拟堆栈的存储方式。

堆栈存储特点: 先进后出,后进先出。


注意: 不再使用的对象,应该不要让变量指向该对象,要让该对象尽快的被垃圾回收期回收。


*/
class StackList{

  Object[] elements;

  int index = 0 ; //当前的索引值

  public StackList(){
  this.elements = new Object[3];
}

//添加内容
public void add(Object o){
  //添加元素之前应该要先检查是否容量够用。
  ensureCapcity();
  elements[index++] = o;
}


//出栈: 删除集合的元素,并且返回。
public Object pop(){
  int tempIndex = --index;
  Object o = elements[tempIndex];
  elements[tempIndex] = null; //让该位置不再 引用着指定的对象,让垃圾回收期赶快回收该垃圾。
  return o;
}


//检查当前的数组使用够用。
public void ensureCapcity(){
  if(index==elements.length){
  //计算一个新的长度
  int newLength = elements.length*2;
  elements = Arrays.copyOf(elements, newLength);
}
}

//获取当前的元素 个数
public int size(){
  return index;
}

}

原文地址:https://www.cnblogs.com/xjt360/p/9425281.html