`
Java杰
  • 浏览: 2740 次
  • 性别: Icon_minigender_1
  • 来自: 浙江
文章分类
社区版块
存档分类
最新评论

Math,String,Randum,enum

 
阅读更多
Java 包:
Java API是java应用程序编程接口,它是运行库的集合,预先定义了一些接口和类,程序员可以直接使用这些已经被打包的接口和类做具体的应用;
Java API提供 lang,util,io,net,sql等常用的包;
Java.lang:包含了java程序的基础类和接口。包装类,Math类,String类等常用的类都包含在此包中。它还提供了用于管理类的动态加载,外部进程创建,主机环境查询和安全策略实施等系统操作的类;
Java.util:包含了系统辅助类,特别是Collection,List和Map等集合类;
Java.io:包含了与输入输出有关的类,如文件操作等类;
Java.sql:包含了与数据库相关的类,如Connection,Statement的类;

枚举(Enum):
是 JDK1.5 开始引入一种新的类型——枚举(Enum),枚举是一组固定的常量组成的类型;
枚举是一种类型,是java.lang.Enum的子类,继承了Enum的很多有用的方法;
由于java中支持单继承,因此枚举类型不能再继承其他类;
枚举像普通的类一样可以添加属性和方法,可以为它添加静态和非静态的属性或方法;
语法:
    访问修饰符 enum 枚举名{
      常量1,常量2;
     //[其他的成员]
      }
在语法中:
使用枚举赋值,只需要输入枚举名 . ;就能将所有的值显示出来;
其他成员,包扣构造方法,置于枚举常量后面;
枚举常量列表必须以分号;结尾;
枚举使代码更易于维护,有助于确保变量指定合法的,或期望的值;
允许用描述性的名称表示数据;

包装类:
Java语言是面向对象的,但是java中的基本类型不是面向对象的,在实际开发中,存在不便。为了解决这个不便,在设计类时为每个基本类型设计了一个对应的类,称为包装类;
包装类均位于java.lang包中;
包装类作为和基本数据类型对应的类型存在,方便对象操作;
包装类含每种基本数据类型的相关属性,最大值,最小值等,以及相关的操作方法;

所有包装类都可以将与之对应的基本数据类型作为参数,类构造它们的实例;
     public Type (Type value)
          示例:Integer i = new Integer(1);
字符串类型;
     public Tpye (String value)
            示例:Integer i = new Integer("123");
除了Character类(char)外,其他包装类可将一个字符串作为参数构造它们的实例;
注意:
1.Boolean类构造方法参数为String类型时,若该字符串内容为true(不考虑大小写),则该Boolean对象表示true,否则表示false;
2.当包装类构造方法参数为String类型时,字符串不能为null,且该字符必须可解析为相应的基本数据类型,否则编译通过,运行时 NumberFormatException 异常;
所有包装类都有如下方法:
   public static Type valueOf(type value)
           示例如:Integer intValue = Integer.valueOf(21);
除了Character类外,其他包装类都有如下方法:
   public static Type valueOf(String s)
        示例如:Integer intValue = Intger.valueOf("21");
包装类转换成基本类型:



示例:
   Integer i = new Integer(25);
       int a = integer.intVaule();
toString();以字符串形式返回包装对象表示的基本类型数据;
方式1:String sex = Character.toString('男');
String id = Integer.toString(25);
方式2:String sex = '男'+"";
String id = 25+"";
parseXXX();把字符串转换为相应的基本数据类型数据;
构造方法: public static type parseType(String type)
(Character除外)
int类型:int num = integer.parseInt("36");
Boolean类型: boolean bool = Bolean.parseBoolean("false");
基本类型和包装类的自动转换:
Integer intObject = 5; 装箱
int intvaule = intObject; 拆卸
装箱:基本类型转换成为包装类的对象;
拆箱;包装类对象转换成为基本类型的值;

所有的包装类都是fianl类型,不能创建它们的子类
JDK1.5后,允许基本数据类型和包装类型进行混合数学运算;
包装类并不是用来取代基本数据类型的;

Math 类 :
Math类中的所有方法都是静态方法。Math是final类,因此没有子类;
Math类提供了一些基本数学运算和几何运算的方法;
常用的方法:
Math.abs(-3.5);返回double的绝对值,3.5;
Match.max(2.5,90.5);返回double值中比较大的一个,返回90.5;
int random = (int)(Math.random()*10);生成一个0-9之间的随机数;(static double random();返回一个double值,该值大于等0,小于1.0)

Random类:
来自java.util.Random类:
要使用Random,必须先创建对象,和导入包;
方法:
Random rand = new Random();//创建一个随机数生成器,使用当前时间的毫秒作为种子
Random rand = new Random(long seed);//使用种子创建一个随机数生成器
rand.nextInt();//生成一个伪随机数,取值为int类型;
rand.nextInt(int n );//,生成一个伪随机数,随机数是0到指定值(int n小于n)之间取值;
在Java中,随机数的产生取决于种子,随机数和种子之间的关系遵从以下两个规则:
*种子不同,产生不同的随机数
*种子相同,即使实例不同也产生相同的随机数

Stringl类:
Java中字符串被作为String类型的对象来处理。String类来自Java.lang包中,默认情况下,该包被自动导入所有的程序;
语法1:
String s = "Hello world";
语法2:
创建String对象:String s = new String ("Hello world");

String类提供了许多方法,例如:获得字符串的长度,对俩个字符串进行比较,连接两个字符串,提取一个字符串中的某一部分等;
获取字符串长度:
字符串.length();
String pwd = "123456":
pwd.length();
字符串比较:
字符串.equals(字符串2);
在使用equals()方法比较俩个字符串时,它逐个的对照组成字符串的每个字符串是否相同。字符串的大小写,也在检查范围;
String name = "我";
if (name.equals("我")) {
//如果name的值等于"我",进入if语句
}//if
Javaz中,双等号(==)和equals()方法应用于俩个字符串,所判断的内容是有差别的。"=="判断的是俩个字符串对象在内存中的地址,就是判断是否同一个字符串对象,而equals()判断的是两个字符串对象的值;
在使用equals()方法比较两个字符串时,对于字符的大小写,也在检查范围,例如"Java"和"java"都是同一个,而equals()方法比较会认为它们不是同一个,如果要忽略大小写,要使用equalsIgnoreCase()方法,这个方法在比较字符串时忽略字符的大小写;

String类提供了两个方法改变字符串中的大小写;
toLowerCase(); 转换字符串中的英文字符为小写;
toUpperCase(); 转换字符串中的英文字符为大写;
字符串.toLowerCase();  字符串.UpperCase();

字符串的连接:
字符串1.concat(字符串2);
字符串2被连到字符串1的后面,成为新值;
String s = new String("你好,");
String name = new String ("张三!");
String sa = s.concat("name");
s跟name的值不变,而字符串sa的内容便是"你好,张三",还有一种连接字符串还经常使用"+"运算符;
String name = "张三";
String say = name+",你好";
字符串提取和查询
字符串是一个字符序列,每个字符都有自己的位置。字符串事实上也是一个字符数组,因此它的索引号位置从0开始到(字符串长度-1)结束.
方法:
//搜索第一个出现的字符ch(或字符串value)
public int indexOf(int ch);
public int indexOf(String value);
//搜索最后一个出现的字符ch(或字符串value)
public int lastIndexOf(int ch);
public int lastIndexOf(String value);
//提取从位置索引号开始的字符串部分
public String substring(int index);
//提取beginindex和endindex之间的字符串部分
public String substring(int beginindex,String endindex);
//返回一个前后不含任何空格的调用的字符串的副本
public String trim();
在String类型储存空间不知有栈,堆!还有一个字符串唱两池;
String s = "java";
String类的对象是不可改变的字符串,本质是字符数组;
常用方法:
indexOf();
subString();
split();
equals();
定义出来的字符串类型会在栈中开辟新的空间存储;
创建对象的字符串类型会在堆中开辟新的空间存储;
String类是不可变对象,在每次对String类型进行改变的时候其实都同于生成了一个新的String对象,然后指向新的String对象,所以经常改变内容的字符串最好不要使用String类型,每次生成新的对象都会对系统性能影响;
StringBuffer是可变的字符串,在每次对StringBuffer对象进行改变时,是对StringBuffer对象本身进行操作改变,而不是生成新的对象,在改变对象的引用.StringBuffer是线程安全的;
StringBuilder和StringBuffer基本相同,区别在与StringBuiler是线程非安全的,理论上效率更快;
  • 大小: 263.2 KB
分享到:
评论

相关推荐

    管系统仿真与GPSSJAVA

    GPSS/Java使用Randum类定义了8个随机数流对象,初始种子值分别为100、200、300、400、500、600、700和800,能够产生8个不同的随机数序列。 GPSS/Java提供了8个随机数发生器,表示为RN$(int n),其中n为随机数发生...

    基于labview的声卡数据采集系统与分析设计毕业论文

    基于labview的声卡数据采集系统与分析设计毕业论文

    Android Studio实现学生信息管理系统源码(高分项目).zip

    Android Studio实现学生信息管理系统源码(高分项目).zip个人经导师指导并认可通过的高分大作业项目,评审分98分,项目中的源码都是经过本地编译过可运行的,都经过严格调试,确保可以运行!主要针对计算机相关专业的正在做大作业的学生和需要项目实战练习的学习者,资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、使用需求,如果有需要的话可以放心下载使用。 Android Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理系统源码(高分项目).zipAndroid Studio实现学生信息管理

    个人毕业设计 - 基于树莓派、OpenCV及Python语言的人脸识别.zip

    个人毕业设计 - 基于树莓派、OpenCV及Python语言的人脸识别.zip

    考虑时变压力角和时变齿侧间隙的直齿轮六自由度平移-扭转耦合非线性动力学程序,包括时域图,相图,FFT图,庞加莱图,分岔图 要想学好齿轮动力学,需要有扎实的齿轮动力学理论和非线性动振动理论 齿轮啮合

    考虑时变压力角和时变齿侧间隙的直齿轮六自由度平移-扭转耦合非线性动力学程序,包括时域图,相图,FFT图,庞加莱图,分岔图。 要想学好齿轮动力学,需要有扎实的齿轮动力学理论和非线性动振动理论。 齿轮啮合刚度建模是齿轮动力学求解的第一步。

    tdm64-gcc-10.3.0-2.exe.zip

    tdm64-gcc-10.3.0-2.exe.zip。资源来源于网络分享,如有侵权请告知!

    安卓项目源码Androidbroadcast电池电量显示源码

    安卓项目源码Android broadcast电池电量显示源码提取方式是百度网盘分享地址

    汽车中间件市场调研报告:2023年全球汽车中间件市场销售额达到了78亿美元

    汽车中间件市场调研报告:2023年全球汽车中间件市场销售额达到了78亿美元 在数字化转型的浪潮中,汽车中间件作为连接硬件与软件的关键桥梁,正引领着汽车行业的新一轮变革。随着全球汽车产业的快速发展,中间件市场规模持续扩大,展现出前所未有的增长潜力。然而,面对复杂多变的市场环境和不断涌现的新技术,企业如何精准把握市场脉搏,实现可持续发展?本文将深入探讨全球及中国汽车中间件市场的现状、趋势及竞争格局,为您揭示咨询的重要性。 市场概况: 根据QYResearch(恒州博智)的统计及预测,2023年全球汽车中间件市场销售额达到了78亿美元(约7803百万美元),预计2030年将达到156亿美元(约15630百万美元),年复合增长率(CAGR)为10.3%(2024-2030)。这一数据不仅彰显了中间件市场的强劲增长动力,也预示着未来巨大的市场空间。 技术创新与趋势: 随着自动驾驶、车联网等技术的不断发展,汽车中间件正面临着前所未有的技术挑战与机遇。新一代中间件需要具备更高的实时性、更低的延迟以及更强的数据处理能力,以满足复杂多变的汽车应用场景。同时,云计算、大数据、人工智能等技术的融合应用,将进

    毕设&课程作业_基于C#的Winform公司管理系统.zip

    计算机系毕业设计

    非常好用的黑莓文件管理器

    亲测可用与黑莓OS6和OS7的文件管理器,测试型号9788、9900、9981

    基于STM8单片机的2.4寸LCD 触摸屏触摸划线实验.zip

    基于STM8单片机的编程实例,可供参考学习使用,希望对你有所帮助

    网络安全-渗透攻防知识点面试题整合

    超全知识点,用来学习都可以。

    2018平安产险数据建模大赛 驾驶行为预测驾驶风险.zip

    驾驶行为风险预测。2018平安产险数据建模大赛 驾驶行为预测驾驶风险Fork或借鉴请注明出处 @ChungKing . Thx比赛链接2018平安产险数据建模大赛 驾驶行为预测驾驶风险数据下载秩第五周 第六周 相关文章http://blog.51cto.com/yixianwei/2120336执照版权所有 (c) ChungKing。保留所有权利。根据MIT许可证授权。

    HTML5+Canvas漂亮的3D烟花2025跨年特效

    元旦烟花html

    大语言模型赋能自动化测试实践、挑战与展望(复旦大学 2024)PPT(54页).pptx

    在21世纪的科技浪潮中,人工智能(AI)无疑是最为耀眼的明星之一,它以惊人的速度改变着我们的生活、工作乃至整个社会的运行方式。而在人工智能的广阔领域中,大模型(Large Models)的崛起更是开启了智能技术的新纪元,引领着AI向更加复杂、高效、智能的方向发展。本文将深入探讨人工智能大模型的内涵、技术特点、应用领域以及对未来的影响。 一、人工智能大模型的内涵 人工智能大模型,顾名思义,是指具有庞大参数规模和数据处理能力的AI模型。这些模型通过深度学习算法,在海量数据上进行训练,能够学习到丰富的知识表示和复杂的模式识别能力。与传统的小型或中型模型相比,大模型在理解自然语言、生成高质量内容、进行跨模态信息处理等方面展现出前所未有的优势。它们不仅能够执行特定的任务,如图像识别、语音识别,还能进行创造性的工作,如文本生成、音乐创作,甚至在某些情况下展现出接近或超越人类的智能水平。 二、技术特点 海量数据与高效训练:大模型依赖于庞大的数据集进行训练,这些数据涵盖了广泛的主题和情境,使得模型能够学习到丰富的语义信息和上下文理解能力。同时,高效的训练算法和硬件加速技术,如TPU(Tensor Processing Unit)和GPU,使得大规模模型的训练成为可能。 自注意力机制与Transformer架构:许多领先的大模型采用了Transformer架构,特别是其自注意力机制,这种设计使得模型在处理序列数据时能够捕捉到长距离依赖关系,极大地提高了模型的表达能力和泛化能力。 多任务学习与迁移学习:大模型通常具备多任务学习的能力,即在一次训练中同时学习多个任务,这有助于模型学习到更通用的知识表示。此外,迁移学习使得这些模型能够轻松适应新任务,只需少量额外数据或微调即可。

    2020中国高校计算机大赛·华为云大数据挑战赛-热身赛.zip

    2020中国高校计算机大赛·华为云大数据挑战赛-热身赛队名无能万金油2020中国高校计算机大赛·华为云大数据挑战赛--热身赛热身赛Rank 7CSDN博客我的博客 (建议直接打开热身赛code.ipynb,里面有详细说明)比赛地址华为云大数据挑战赛--热身赛赛题说明热身赛题——交通流量预测随着电子信息和移动通信技术高速发展和不断融合,人工智能在各个领域都相继取得了巨大的突破,城市智能体也应运而生,而城市交通又是城市智能体的核心。交通流量数据既是城市交通中的基础数据,又是反应交通状况的重要指标之一,准确预测交通流量对城市交通具有重大意义。本题以交通流量预测为目标,邀请各个队伍以历史交通流量数据建立对应的算法模型,预测目标流量数据,通过预测值和真实值之间的对比得到预测准确率,以此来评估各队伍所提交的预测算法。要求lightgbm 2.3.0学习熊猫==0.24.2泡菜numpy全面质量管理scipy ==>1.1.0##数据在trian文件夹下:1月12日 ~2月8日 各路口数据train/01-12/chongzhi_beie

    使用Hadoop、Spark等实现的大数据平台项目.zip

    使用Hadoop、Spark等实现的大数据平台项目大数据项目集1. 基于Hadoop的离线用户行为日志分析(weblog)技术栈Hadoop豆 点击流数据处理 点击会话流模型构建 Hive明细表构建 用户行为指标分析2. 基于Akka实现RPC通信(akka_rpc)技术栈Akka 模拟Hadoop集群间通信 模拟Spark集群间通信 模拟Yarn通信3. 广告数据管理平台(dmp)技术栈Spark、Scala 广告日志ETL 报表统计 用户画像构建 广告标签统计 DMP结果入库HBase4. 基于Spark MLLib实现个性化推荐(mllib)技术栈Spark、ScalaMovieLens 数据模型构建 冷启动启动时用户随机对10部电影评分 切分数据集 ALS模型构建 模型评估 个性化推荐5. 基于Flink对CDN日志分析(flink-train)技术栈Flink、Scala 模拟Kafka生产者生成日志数据 CDN日志分析

    数据可视化大屏展示.zip

    数据可视化大屏展示维兹前言提到数据大屏,通常大家的印象就是各种图表、表格的数据展示,然后不断地轮询后端接口。对于前端开发者来说,更多的关注点在于布局问题、图表的兼容性问题以及窗口变化后图表样式问题。对于后端来说,主要考虑的是如何在不断的请求中减轻服务器的压力。但实际上,数据大屏的需求还远不止于此前端发布后应当可以作为应用直接运行,而不需要手动输入地址进行预览。 需要减轻服务器的压力,避免频繁的数据请求。 当前后端任何一方或双方都离线的情况下,数据仍能正常运行。 需要日志的存储,以便随时查看问题。 需要调用系统的能力和跨域调用API,以增加数据展示的灵活性。解决方案我采用了GO和lorca的方式来解决以上问题特征打包体积轻量,仅20MB。使用无头浏览器lorca,可自定义Chrome和JavaScript之间的交互。支持交叉编译到Windows和Mac系统。离线状态下也可以正常运行。可以运行本地服务,减轻服务器压力。编译速度快,运行性能优秀。依赖项该项目的依赖项如下Go 1.20+节点 14.8+整体方案演示下载对应的安装包

    DNAStar-个人学习

    仅限个人学习,禁止商业用途!

    cmn.txt的英文句子经过分词、转为小写处理得到的结果存放的文件

    cmn.txt的英文句子经过分词、转为小写处理得到的结果存放的文件

Global site tag (gtag.js) - Google Analytics