java socket参数详解:BackLog
- - 开源软件 - ITeye博客 java socket参数详解:BackLog. 输入连接指示(对连接的请求)的最大队列长度被设置为 backlog 参数. 如果队列满时收到连接指示,则拒绝该连接. backlog参数必须是大于 0 的正值. 如果传递的值等于或小于 0,则假定为默认值. 经过测试这个队列是按照 FIFO(先进先出)的原则.
public static void testBase(int i)
{
i = 2;
} int i = 10; System.out.println(i);//10 testBase(i); System.out.println(i); //10
public static void testObj(Object o)
{
o = new Object();
} Object o = new Object(); System.out.println(o);// java.lang.Object@1ff61bcf testObj(o); System.out.println(o);//java.lang.Object@1ff61bcf
public class S
{
private Object o = new Object();
private int i = 2;
public Object getO()
{
return o;
}
public void setO(Object o)
{
this.o = o;
}
public int getI()
{
return i;
}
public void setI(int i)
{
this.i = i;
}
}
测试方法:public static void testA(S s)
{
s.setI(100);
s.setO(new Object());
} S s = new S(); System.out.println(s.getI()+","+s.getO());// 2,java.lang.Object@11b75be2 testA(s); System.out.println(s.getI()+","+s.getO());//100,java.lang.Object@1cf15b84
package test;
public class A
{
int t = 6;
Object obj = new Object();
public static void main(String[] args)
{
A a = new A();
a.func(a.t,a.obj);//问t和obj的值是否变化,答案:不变化
}
public void func(int t,Object obj)
{
t = 7;
obj = null;
}
}
public static void testArr(int[] arr)
{
arr = null;
}测试:int[] arr = {1,2};
System.out.println(arr[0]);//1
testArr(arr);
System.out.println(arr[0]); //1
public static void testArr(int[] arr)
{
arr[0] = 100;
}测试:int[] arr = {1,2};
System.out.println(arr[0]);//1
testArr(arr);
System.out.println(arr[0]);//100
public static void testWrapper(Float f)
{
f = 100.0f;
}测试:Float f = 12.0f; System.out.println(f);//12.0 testWrapper(f); System.out.println(f);//12.0
public static void testStr1(String str)
{
str = "testOK";
}测试:String str = "test"; System.out.println(str);//test testStr1(str); System.out.println(str);//test根据前面的思路,字符串也是对象,参数拷贝的是对象的地址,在方法内部将参数指向另一个堆对象并不影响原始对象引用的指向。
public static void testStr2(String str)
{
str = str.concat("OK");
str = str.toUpperCase();
}测试:String str = "test"; System.out.println(str);//test testStr2(str); System.out.println(str);//test
public static void testStr3(String str)
{
str += "OK";
}测试:String str = "test"; System.out.println(str);//test testStr3(str); System.out.println(str);//test如果你以为第二次输出testOK,那就错啦,String类的’+‘是经过重载的,编译时会还原成StringBuilder的append操作,并且new了一个StringBuilder对象:
str += "OK";
str = new StringBuilder(str).append("OK").toString();//编译时会还原成这样
public static void testStringBuilder(StringBuilder sb)
{
sb = new StringBuilder("testOK");
} 测试:StringBuilder sb = new StringBuilder("test");
System.out.println(sb.toString());//test
testStringBuilder(sb);
System.out.println(sb.toString());//test 6.2在方法内部调用StringBuffer或StringBuilder的append方法: public static void testStringBuilder(StringBuilder sb)
{
sb.append("OK");
} 测试:StringBuilder sb = new StringBuilder("test");
System.out.println(sb.toString());//test
testStringBuilder(sb);
System.out.println(sb.toString());//testOK
public static void swap(Integer a, Integer b)
{
Integer temp = a;
a = b;
b = temp;
}这根本不能交换两个数.