牛客java训练题 day1

9.24 day1 Q

1.

this 指针是用来干什么的?

2.基类和派生类分别是指什么?

3.为什么方法中不能写静态变量

4.

解释一下ASCII码和ANSI码和两者的区别

5.简述j ava.io java.sql java.awt java.rmi 分别是什么类型的包

6.

看下面一段代码:

public class Test{private static int i = 1;public int getNext(){return i++;}public static void main(String[] args){Test test = new  Test();Test testObject = new Test();test.getNext();testObject.getNext();Sout(testObject.getNext());}
}

最后打印的值

7.

以下的代码结果是:

​
public class foo {public static void main(String sgf[]) {StringBuffer a=new StringBuffer("A");StringBuffer b=new StringBuffer("B");operate(a,b);System.out.println(a+"."+b);}static void operate(StringBuffer x,StringBuffer y) {x.append(y);y=x;}
}

8.

分析此构造结果:

class Base{public Base(String s){System.out.print("B");}
}
public class Derived extends Base{public Derived (String s) {System.out.print("D");}public static void main(String[] args){new Derived("C");}
}

10.

说一说HashMap 和 Hashtable 两者的区别?

1.线程安全性:

2.null键和null值

3.继承关系

4.效能

5.初始容量和负载因子

6.迭代顺序

12.

那些类实现或继承了COllection接口和Map接口?

13.

看一下的代码,其中能正常执行的有

public static void main(String args[]) {
byte a = 3;
byte b = 2;
b = a + b;
System.out.println(b);
}
// A
public static void main(String args[]) {
byte a = 127;
byte b = 126;
b = a + b;
System.out.println(b);
}
// B
public static void main(String args[]) {
byte a = 3;
byte b = 2;
a+=b;
System.out.println(b);
}
//C
public static void main(String args[]) {
byte a = 127;
byte b = 127;
a+=b;
System.out.println(b);
}
//D

14.说一说实例变量、局部变量、类变量和final变量之间的异同点

实例变量

是在类中声明的变量,可以具有访问修饰符(public,private,protected等)可以通过对象引用以及在类中的方法进行访问和修改

只有对象被销毁后才会被销毁

局部变量

局部变量不具有默认值,必须初始化

在代码块执行结束之后被销毁

类变量

用static修饰的变量

会一直存在于内存中,直到程序退出或类被卸载

final 变量

final变量是一个常量,一旦被赋值后就不能再更改它的值

final变量可以是实例变量,局部变量或类变量

final变量必须在声明时或构造函数中进行初始化,且不能再被修改

final变量在java编译器中有重要作用,提供了不可变性和线程安全性

public class VariableExample {// 实例变量private int instanceVariable;// 类变量private static String classVariable = "Hello";
​public void exampleMethod() {// 局部变量int localVar = 10;
​// 使用实例变量和类变量instanceVariable = 20;System.out.println("Instance Variable: " + instanceVariable);System.out.println("Class Variable: " + classVariable);
​// 使用局部变量System.out.println("Local Variable: " + localVar);// 使用final变量final int finalVar = 30;System.out.println("Final Variable: " + finalVar);// 错误示例:finalVar = 40;  // 无法修改final变量的值}public static void main(String[] args) {VariableExample obj = new VariableExample();obj.exampleMethod();}
}

15.

Q: 以下代码将打印出

 public static void main (String[] args) { String classFile = "com.jd.". replaceAll(".", "/") + "MyClass.class";System.out.println(classFile);
}
9.24 java 1 A

1.

this指针是隐藏的,可以使用该指针来访问调用对象中的数据。

保证每个对象拥有自己的成员,但共享处理这些数据的代码

2.

基类是继承关系中位于最高i级别的类,也就是父类

派生类是从基类继承属性和方法的类

3.

因为被static修饰的变量称为静态变量,静态变量属于整个类,而局部变量属于方法,只在该方法内有效,两者矛盾

public class Test {static String x = "1";static int y = 1;public static void main(String args[]){static int z = 2;//error}
}

4.

相同点:都是用于表示字符的编码方案

ASCII码无法包括所有国际字符

ANSI码使用更加广泛,因为它包含的更多

标准ASCII只使用7 个bit

ANSI就是GB2312

ASCII码是ANSI码的子集

都不能打印,因为包含一些特殊空字符

5.

java,io提供了全面的IO接口。包括:文件读写、标准设备输出

java.sql:提供使用编程语言访问并处理在数据源中的数据的API。此API包括一个框架,凭借此框架可以动态地安装不同驱动程序来访问不同数据源

java.awt:是一个软件包,包含用于创建用户界面和绘制图形图像的所有分类。功能:包含用于创建用户界面和绘制图形图像的所有类

java.rmi:提供RMI包。RMI指的是远程方法调用。它是一种机制。能够让某个java虚拟机上的对象调用另一个java虚拟机中的对象上的方法

6.

答案是:3

return i++,先返回i,然后i+1

7.

简单来说就是有a,b,x,y四个指针

往方法中传参,传的仅仅知识地址,而不是实际内存,所以y = x ,并不是b=a的执行,这里只是y指向了a指向的地址

8.

子类构造方法在调用时必须先调用父类的,由于父类没有无参构造,所以只能在子类中显性调用,在子类构造方法的第一行

public Derived extends Base{
public Derived(String s){super("s");
System.out.print("D")
}
}

9.

img

这个表记住

10.

Hashtable and HashMap 的区别:

1.线程安全性:Hashtable是线程安全的,而HashMap不是。Hashtable中的方法是同步的,多个线程可以安全的同时访问和修改Hashtable 的内容

2.null键和null值:

HashMap允许使用null作为键和值,而Hashtable不允许。在HashMap中,可以将null作为键和值都可以

3.继承关系:

都是基于哈希表实现的,Hashtable是基于哈希表和同步机制的组合实现的

4.效能:HashMap 通常比 Hashtable具有更好的性能。由于Hashtbale 中的方法是同步的,这会在多线程环境下引入一定的性能开销。而HashMap不具备同步机制,可以在单线程环境或自行进行线程同步时提供更高的性能

5.初始容量和负载因子:HashMap允许设置初始容量和负载因子。初始容量是指哈希表初始的大小,负载因子表示哈希表在容量自动扩充之前可以达到多满的程度。而Hashtable有一个默认的初始容量,且在内部逻辑中使用了默认的负载因子

6.迭代顺序:HashMap的迭代顺序不保证是特定,他可能会随着时间和容量的变化而变化。而Hashtable的迭代顺序是按照插入顺序保持不变的

在这里帮大家总结一下hashMap和hashtable方面的知识点吧:

  1. 关于HashMap的一些说法: a) HashMap实际上是一个“链表散列”的数据结构,即数组和链表的结合体。HashMap的底层结构是一个数组,数组中的每一项是一条链表。

  2. b) HashMap的实例有俩个参数影响其性能: “初始容量” 和 装填因子。 c) HashMap实现不同步,线程不安全。 HashTable线程安全

  3. d) HashMap中的key-value都是存储在Entry中的。

  4. e) HashMap可以存null键和null值,不保证元素的顺序恒久不变,它的底层使用的是数组和链表,通过hashCode()方法和equals方法保证键的唯一性

  5. f) 解决冲突主要有三种方法:定址法,拉链法,再散列法。HashMap是采用拉链法解决哈希冲突的。

  6. 注: 链表法是将相同hash值的对象组成一个链表放在hash值对应的槽位;

  7. 用开放定址法解决冲突的做法是:当冲突发生时,使用某种探查(亦称探测)技术在散列表中形成一个探查(测)序列。 沿此序列逐个单元地查找,直到找到给定 的关键字,或者碰到一个开放的地址(即该地址单元为空)为止(若要插入,在探查到开放的地址,则可将待插入的新结点存人该地址单元)。

  8. 拉链法解决冲突的做法是: 将所有关键字为同义词的结点链接在同一个单链表中 。若选定的散列表长度为m,则可将散列表定义为一个由m个头指针组成的指针数 组T[0..m-1]。凡是散列地址为i的结点,均插入到以T[i]为头指针的单链表中。T中各分量的初值均应为空指针。在拉链法中,装填因子α可以大于1,但一般均取α≤1。拉链法适合未规定元素的大小。

  9. Hashtable和HashMap的区别: a) 继承不同。

    public class Hashtable extends Dictionary implements Map    
    public class HashMap extends  AbstractMap implements Map    

  10. b) Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。在多线程并发的环境下,可以直接使用Hashtable,但是要使用HashMap的话就要自己增加同步处理了。

  11. c) Hashtable 中, key 和 value 都不允许出现 null 值。 在 HashMap 中, null 可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为 null 。当 get() 方法返回 null 值时,即可以表示 HashMap 中没有该键,也可以表示该键所对应的值为 null 。因此,在 HashMap 中不能由 get() 方法来判断 HashMap 中是否存在某个键, 而应该用 containsKey() 方法来判断。

  12. d) 两个遍历方式的内部实现上不同。Hashtable、HashMap都使用了Iterator。而由于历史原因,Hashtable还使用了Enumeration的方式 。 e) 哈希值的使用不同,HashTable直接使用对象的hashCode。而HashMap重新计算hash值。

  13. f) Hashtable和HashMap它们两个内部实现方式的数组的初始大小和扩容的方式。HashTable中hash数组默认大小是11,增加的方式是old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。 注: HashSet子类依靠hashCode()和equal()方法来区分重复元素。 HashSet内部使用Map保存数据,即将HashSet的数据作为Map的key值保存,这也是HashSet中元素不能重复的原因。而Map中保存key值的,会去判断当前Map中是否含有该Key对象,内部是先通过key的hashCode,确定有相同的hashCode之后,再通过equals方法判断是否相同

11.

[a,b):包括a,但不包括b

12.

img

13.

byte类型的值在进行运算的时候,会强行转化为int

A and B 都是左边是byte,右边是int,转换不了

而C,D语句中用的是 a+=b 的语句,此语句会将被赋值的变量自动强制转化为相对应的类型

14.

float占4个字节为什么比long占8个字节大呢,因为底层的实现方式不同。

浮点数的32位并不是简单直接表示大小,而是按照一定标准分配的

第1位,符号位,即S

接下来8位,指数域,即E。

剩下23位,小数域,即M,取值范围为[1 ,2 ) 或[0 , 1)

然后按照公式: V=(-1)^s * M * 2^E

也就是说浮点数在内存中的32位不是简单地转换为十进制,而是通过公式来计算而来,通过这个公式虽然,只有4个字节,但浮点数最大值要比长整型的范围要大

不行

15.

replaceAll()函数的第一个参数是一个正则表达式,而“."在正则表达式中代表的了全部字符

R:

1.接口与抽象类是不同的概念,抽象类是捕捉子类的通用特性,接口是抽象方法的集合

2.实现接口必须实现接口的所有方法

3.接口可以继承一个或多个接口,抽象类只能继承一个类或多个接口

4.一个类只能继承一个类,但是可以实现多个接口

一个接口可以实现多个接口的原因是多重继承的替代方案,多态化实现,接口的解耦和复用,使用不同的业务需求。如果没有实现所有接口的方法,那么该类必须声明为抽象类

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/141155.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

自定义数据类型

前言:小伙伴们又见面啦,今天这篇文章,我们来谈谈几种自定义数据类型。 目录 一.都有哪些自定义数据类型 二.结构体 结构体内存对齐 1.如何对齐 2.为什么要对齐 3.节省空间和提升效率的方法 (1)让占用空间小的成员…

SD-MTSP:萤火虫算法(FA)求解单仓库多旅行商问题MATLAB(可更改数据集,旅行商的数量和起点)

一、萤火虫算法(FA)简介 萤火虫算法(Firefly Algorithm,FA)是Yang等人于2009年提出的一种仿生优化算法。 参考文献:田梦楚, 薄煜明, 陈志敏, et al. 萤火虫算法智能优化粒子滤波[J]. 自动化学报, 2016, 42(001):89-97. 二、单仓…

Java基础常考知识点(基础、集合、异常、JVM)

作者:逍遥Sean 简介:一个主修Java的Web网站\游戏服务器后端开发者 主页:https://blog.csdn.net/Ureliable 觉得博主文章不错的话,可以三连支持一下~ 如有需要我的支持,请私信或评论留言! Java基础常考知识点…

【golang】调度系列之sysmon

调度系列 调度系列之goroutine 调度系列之m 调度系列之p 在golang的调度体系中,除了GMP本身,还有另外一个比较重要的角色sysmon。实际上,除了GMP和sysmon,runtime中还有一个全局的调度器对象。但该对象只是维护一些全局的数据&…

ROS2 的行为树 — 第 1 部分:解锁高级机器人决策和控制

一、说明 在复杂而迷人的机器人世界中,行为树(BT)已成为决策过程中不可或缺的一部分。它们提供了一种结构化、模块化和高效的方法来对机器人的行为进行编程。BT起源于视频游戏行业,用于控制非玩家角色,他们在机器人领域…

FPGA板卡启动以及LED灯带调试

环境配置 软件: MobaXterm(free版本即可)下载教程参考: MobaXterm(终端工具)下载&安装&使用教程_蜗牛也不慢......的博客-CSDN博客 Win32 Disklmager 下载教程参考: 不分类工具&am…

公众号迁移多久可以完成?

公众号账号迁移的作用是什么?只能变更主体吗?长期以来,由于部分公众号在注册时,主体不准确的历史原因,或者公众号主体发生合并、分立或业务调整等现实状况,在公众号登记主体不能对应实际运营人的情况下&…

在北京多有钱能称为富

背景 首先声明,此讨论仅限个人的观点,因为我本身不富嘛,所以想法应该非常局限。 举个栗子 富二代问我朋友,100~1000w之间,推荐一款车? 一开始听到这个问题的时候,有被唬住,觉得预…

基于Python+Django的热门旅游景点数据分析系统的设计与实现(源码+lw+部署文档+讲解等)

前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 👇🏻…

什么是IoT数字孪生?

数字孪生是资产或系统的实时虚拟模型,它使用来自连接的物联网传感器的数据来创建数字表示。数字孪生允许您从任何地方实时监控设备、资产或流程。数字孪生用于多种目的,例如分析性能、监控问题或在实施之前运行测试。从物联网数字孪生中获得的见解使用户…

18795-2012 茶叶标准样品制备技术条件

声明 本文是学习GB-T 18795-2012 茶叶标准样品制备技术条件. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了各类茶叶(除再加工茶)标准样品的制备、包装、标签、标识、证书和有效期。 本标准适用于各类茶叶(除再加工茶)感官品质…

怎么在OPPO手机桌面上添加文字?便签桌面插件添加教程

很多年轻女性在选择手机时,都比较青睐于设计时尚靓丽、轻薄且续航好、系统流畅、拍照清晰的OPPO手机,并且OPPO为不同的用户提供了高中低不同价格档位的手机型号,能够满足绝大多数女性消费者的使用需求。 不过有不少OPPO手机用户表示&#xf…

华为NFC设置教程(门禁卡/公交卡/校园卡等)

今天把华为NFC设置教程分享给大家 出门带门禁卡、校园卡、银行卡、身份证……东西又多,携带又麻烦,还容易搞丢,有没有一种方法可以把它们都装下?有!只要一部手机,出门不带卡包,各种证件&#x…

【知识分享】Java获取全年每个月的有几周且每周是几号到几号

加哥本周给大家分享一期怎么用java把全年每个月有几周,本周是几号到几号的工具类。便于大家根据需求获取想要的形式进行改造。话不多说,直接给大家上代码。 package com.techfantasy.common.utils; import com.techfantasy.common.entity.DateRange; i…

安全测试之w3af 安装

背景: 学习安全测试时,离不开一些安全扫描工具,在类目众多的工具中,w3af是个绕不开的集成工具。由于没有linux环境,故在windows下利用wsl进行部署。亦可通过其它虚拟机安装亦可。 借鉴:Win10下安装w3af_Da…

NSSCTF做题

[第五空间 2021]WebFTP 打开题目 发现是登录的界面 用admin和password试一下发现不行 用dirsearch扫一下 发现了git泄露 但是用githack下载不下来文件 去网上查了一下webftp 发现是一个在线php文件管理系统 WebFTP——在线FTP工具:强大的PHP在线文件管理系统-時日 在这篇博客…

leetcode top100(20) 搜索二维矩阵 II

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性: 每行的元素从左到右升序排列。每列的元素从上到下升序排列。 示例 1: 输入:matrix [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,2…

6.1 使用scikit-learn构建模型

6.1 使用scikit-learn构建模型 6.1.1 使用sklearn转换器处理数据6.1.2 将数据集划分为训练集和测试集6.1.3 使用sklearn转换器进行数据预处理与降维1、数据预处理2、PCA降维算法 代码 scikit-learn(简称sklearn)库整合了多种机器学习算法,可以…

mysql Your password does not satisfy the current policy requirements

在修改密码时遇到 Your password does not satisfy the current policy requirements 原因:您的密码不符合当前策略要求,最好是把密码设置成复杂的,包括字母大小写、数字、特殊字符。 如果你还是先把数据库密码改简单,比如你本地…

C++【个人笔记1】

1.C的初识 1.1 简单入门 #include<iostream> using namespace std; int main() {cout << "hello world" << endl;return 0; } #include<iostream>; 预编译指令&#xff0c;引入头文件iostream.using namespace std; 使用标准命名空间cout …