------<ahref="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------

          

                    黑马程序猿——15,String。基本数据类型包装对象

/*
字符串相关的练习
*/ /*
求两个字符串中最大的同样子串。
思路:1。将短的子串依照长度递减的方式获取
2,将每次获取到的子串去长串中推断是否包含 */
class Zfclx
{
public static void main(String[] args)
{ String a="kjesqwersjfnqwg";
String b="ccaaqwerxyhs";
String c= zichuan(b,a);
String d= zichuan2(b,a);
System.out.println("c="+c);
} public static String zichuan(String s1,String s2)
{
if( s1.length()<s2.length())
{
String s3=" ";
s3=s1;
s1=s2;
s2=s3;
}
String op="";//这里设定一个变量,用来存储返回的字符串
String[][] ui=new String[s2.length()][]; w: for(int x=0;x<s2.length();x++)
{
for(int y=0,z=s2.length()-1-x; z!=s2.length();y++,z++)
{
if(s1.contains(s2.substring(y,z+1)))
{
op=s2.substring(y,z+1);
soc(op); break w ;//找到之后直接跳出循环 }
} }
return op;
}
public static String zichuan2(String s1,String s2)
{
String max="";
String min="";
max =( s1.length()<s2.length())?s2:s1;
min = ( s1.length()<s2.length())?s1:s2; String op="";
String[][] ui=new String[min.length()][]; w: for(int x=0;x<min.length();x++)
{
for(int y=0,z=min.length()-1-x; z!=min.length();y++,z++)
//定义y在左边指示。定义z在右边指示
{
if(max.contains(min.substring(y,z+1)))
{
op=min.substring(y,z+1);
soc(op); break w ; }
} }
return op;
} public static void soc(Object obj)
{
System.out.println(obj);
} }
/*
以上代码编译执行结果例如以下:
qwer
qwer
c=qwer
*/

——————切割线——————

 

 

/*
StringBuffer字符串缓冲区的方法介绍
注意:StringBuilder是jdk1.5之后出现的,也相当于一个容器,
其功能和StringBuffer几乎相同,可是。
StringBuffer是线程同步的(一个线程执行完之后下一个线程才干够进来执行)
StringBuilder是线程不同步的(能够多个线程同一时候对其执行) 版本号升级因素:提高效率,简化书写。提高安全性
*/ class Zfclx3
{
public static void main(String[] args)
{
StringBuffer a=new StringBuffer();//StringBuffer是一个容器,长度能够变化
StringBuffer a2= a.append(26);//把26加入进去容器里面再返回容器
soc("a==a2---"+(a==a2));//推断a与a2是否是同一个对象。打印的是a==a2---true a.append("卡卡").append(false).append(10);//调用链
soc(a);//都是以字符串的形式打印26卡卡false10 a.insert(2,"神");//插入操作。在第二位插入
soc(a);//打印26神卡卡false10
//a.insert(200,"神");//角标越界异常 a.delete(5,5);//相当于没有操作
soc("a---------------"+a);
//打印a---------------26神卡卡false10 a.delete(5,7);//剪切第5位到第6位,注意:不包含第七位
soc("剪切后的a="+a);//打印的是剪切后的a=26神卡卡lse10
//a.delete(0,a.length());//清空缓冲区(清空了容器内部) a.deleteCharAt(2);//删除第二位字符
soc("a.deleteCharAt(2)----"+a); //a.charAt(2);//获取第二位字符
//a.indexOf("0");//查找字符串中字符0的位置
//a.substring(0,a.length());//获取从第0位到a.length()-1位的字符串 a.replace(0,3,"kkkk");//把字符串中的第1位到第2位(不包含第3位)替换成kkkk
soc("replace---"+a); StringBuffer a3=new StringBuffer("hsjd");//容器里面装的是字符串hsjd
soc("a3="+a3);//打印的是hsjd
soc2(a3); a3.setCharAt(0,'n');//该方法没有返回值,改动完之后就没有返回了
soc(a3.toString()); a3.reverse();//反转
soc("reverse---"+a3); StringBuffer a4=new StringBuffer("abcdefgh");
char[] charsz=new char[8];
a4.getChars(2,5,charsz,1);
/*
获取字符串中第2位到第4位字符(不包含第5位)
然后从charsz数组的第1位開始存放 */
for( int x=0; x<charsz.length; x++ )
{
System.out.println("charsz["+x+"]="+charsz[x]);
} }
public static void soc(Object obj)
{
System.out.println(obj); }
public static void soc2(Object obj)
{
StringBuffer a= (StringBuffer)obj;//父类强制转换成子类
a.deleteCharAt(0);
System.out.println(a); } }
/*
以上代码编译执行结果:
a==a2---true
26卡卡false10
26神卡卡false10
a---------------26神卡卡false10
剪切后的a=26神卡卡lse10
a.deleteCharAt(2)----26卡卡lse10
replace---kkkk卡lse10
a3=hsjd
sjd
njd
reverse---djn
charsz[0]=
charsz[1]=c
charsz[2]=d
charsz[3]=e
charsz[4]=
charsz[5]=
charsz[6]=
charsz[7]=
*/

——————切割线——————

 

/*
基本数据类型的对象包装类 byte Byte
short Short
int Integer
long Long
boolean Boolean
float Float
double Double
char Character
*/ class Zfclx4
{
public static void main(String[] args)
{
soc("Integer.MAX_VALUE="+Integer.MAX_VALUE);//打印整数类型的最大值 /*
基本数据类型转成字符串:
基本数据类型+""
基本数据类型.toString(基本数据类型值);
比如:Integer.toString(25); 字符串转成数据类型:(除了char以外)
xxx a=Xxx.parseXxx(String);
比如:int a= Integer.parseInt("26");//数字型的字符串转换成int型数据
double a=Double.parseDouble("26.23");
boolean a=Boolean.parseBoolean("true");
short b=Short.parseShort("24"); */
//int b=Integer.parseInt("m123");//数字格式异常,执行出问题
//int b=Integer.parseInt("0x123");//数字格式异常,执行出问题
//int b=Integer.parseInt("123");//数字格式异常。执行出问题 //十进制转其它进制:
String k=Integer.toBinaryString(36);
soc("Integer.toBinaryString(36)="+k);
String k2=Integer.toHexString(36);
soc("Integer.toHexString(36)="+k2);
String k3=Integer.toOctalString(36);
soc("Integer.toOctalString(36)="+k3); int k6=Integer.parseInt("26");
soc("Integer.parseInt(\"26\")---"+k6); //其它进制转成十进制
int x= Integer.parseInt("110",10);
soc("Integer.parseInt(\"110\",10)---"+x); int x2=Integer.parseInt("110",2);
soc("Integer.parseInt(\"110\",2)---"+x2); int x3=Integer.parseInt("110",8);
soc("Integer.parseInt(\"110\",8)---"+x3); int x4= Integer.parseInt("110",16);
soc("Integer.parseInt(\"110\",16)---"+x4); int x5= Integer.parseInt("1c",16);
soc("Integer.parseInt(\"1c\",16)---"+x5); System.out.println("HelloWorld!");
}
public static void soc(String obj)
{
System.out.println(obj);
}
} /*
以上代码编译执行结果:
Integer.MAX_VALUE=2147483647
Integer.toBinaryString(36)=100100
Integer.toHexString(36)=24
Integer.toOctalString(36)=44
Integer.parseInt("26")---26
Integer.parseInt("110",10)---110
Integer.parseInt("110",2)---6
Integer.parseInt("110",8)---72
Integer.parseInt("110",16)---272
Integer.parseInt("1c",16)---28
Hello World! */

 

/*

     基本数据类型对象包装的jdk1.5版本号新特性

*/

 

class  Zfclx5
{
publicstatic void main(String[] args)
{
//Integer a= new Integer(12);
Integer a=12;//与上句效果一样,可是这里的12 是一个对象。! !
a=a+3;//这句话编译执行通过,这里的3是一个int型数据。
/*
这句话过程是这种:
先是a.intValue()+3
然后再把其和赋值给a。再封装成一个对象
*/
Integer b=145;
Integer c=145;
soc("b==c---"+(b==c));//b==c---false
//对象不一样 Integer b2=127;
Integer c2=127;
soc("b2==c2---"+(b2==c2));//b==c---true
//对象同样
/*
这里为何会出现两种结果?
由于。在新特性中,假设数据没有超过byte范围且已经存在就不会再新建对象
假设数值超过了byte范围且已经存在就须要再新建对象
*/ System.out.println("HelloWorld!");
}
public static void soc(String str)
{
System.out.println(str);
}
}

黑马程序猿——15,String,StringBuffer,基本数据类型包装对象的更多相关文章

  1. 黑马程序猿————Java基础日常笔记---反射与正則表達式

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 黑马程序猿----Java基础日常笔记---反射与正則表達式 1.1反射 反射的理解和作用: 首 ...

  2. 黑马程序猿——25,打印流,合并流,对象序列化,管道流,RandomAccessFile

    ------<ahref="http://www.itheima.com" target="blank">Java培训.Android培训.iOS培 ...

  3. 黑马程序猿_Java 代理机制学习总结

    -------<a href="http://www.itheima.com/"">android培训</a>.<a href=" ...

  4. JAVA基础--常用类 String,StringBuffer, 基础数据类型包装类, Math类, Enum类

    字符串相关类: String, StringBuffer String类为不可变的字符序列 String s1="hello"; String s2="hello&quo ...

  5. 黑马程序猿_7K面试题之交通灯系统

    交通灯信号模拟系统 一.概述 模拟实现十字路口的交通灯管理系统逻辑,详细需求例如以下:(需求直接来源于老师的文档) ①      异步随机生成依照各个路线行驶的车辆. 比如: 由南向而来去往北向的车辆 ...

  6. 黑马程序猿——JAVA高新技术——反射

    ----------android培训.java培训.java学习型技术博客.期待与您交流!------------ 一.对于反射的概念 对于JAVA反射机制是在执行状态中,对于随意一个类.都可以知道 ...

  7. 黑马程序员——JAVA基础之基本数据类型包装类和1.5JDK新特性装箱

    ------- android培训.java培训.期待与您交流! ---------- 基本数据类型包装类: byte Byte short Short int Integer char Charac ...

  8. 黑马程序猿——Java中的类载入器

    ------- android培训.java培训.期待与您交流! -------- 类载入器 Java虚拟机中能够安装多个类载入器,系统默认三个主要类载入器,每一个类负责载入特定位置的类: BootS ...

  9. 黑马程序猿 IO流 ByteArrayInputStream与ByteArrayOutputStream

    ---------------------- ASP.Net+Unity开发..Net培训.期待与您交流! ---------------------- package cn.itcast.IO; i ...

随机推荐

  1. dp之完全背包 hdu--2159一维数组做法

    #include <iostream>#include <stdio.h>#include <string.h>using namespace std;int ma ...

  2. Resource Access Based on Multiple Credentials

    A collection of multiple user credentials each associated with one of multiple different users is ob ...

  3. 【OC学习-8】存取器方法?getter和setter?事实上就是赋值和返回值的两种函数

    我们在声明类的时候,有实例变量+方法(函数),这些实例变量假设默认的话都是protected类型,一般无法直接訪问.更别提赋值和调用了,所以就产生了两种函数,getter函数就是可以返回实例变量的值, ...

  4. 让checkbox不选中

    今天在做项目的时候.遇到一个问题.须要把选中的checkbox置空,即将选中的checkbox不选中. 最后,发现一个方法非常好使,特此记录. $("input[type='checkbox ...

  5. C# wpf程序获取当前程序版本

    C# wpf程序获取当前程序版本 /// <summary>         /// 获取当前系统的版本         /// </summary>         /// ...

  6. [NOI.AC#34]palinedrome 字符串hash+贪心

    容易看出,只要从两边往中间扫描,碰到相等的就直接分割然后加入答案即可,判断相等用字符串hash #include<bits/stdc++.h> #define REP(i,a,b) for ...

  7. Day5下午解题报告1

    预计分数:100+60+30=190 实际分数:100+60+30=190 终于有一道无脑T1了哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈 ...

  8. 【2017"百度之星"程序设计大赛 - 初赛(A)】小C的倍数问题

    [链接]http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=775&pid=1001 [题意] 在这里写题意 [题 ...

  9. Spring学习总结(5)——IOC注入方式总结

    一.构造注入 在类被实例化的时候,它的构造方法被调用并且只能调用一次.所以它被用于类的初始化操作.<constructor-arg>是<bean>标签的子标签.通过其<v ...

  10. spring+mybatis+Atomikos JTA事务配置说明

    一.概览 Atomikos是一个公司名字,旗下最著名的莫过于其Atomikos的事务管理器产品.产品分两个:一个是开源的TransactionEssentials,一个是商业的ExtremeTrans ...