mysql isodd,牛客网刷题笔记——错题集2

1、代码 的运行结果是()

1 package com.sunline.java;

2 public class A implements B extends C{

3 public static void main(String args[]){

4 System.out.println("hello sunline!");

5 }

6 }

错误答案:在控制台打印hello sunline!

正确答案:编译错误

解析:java中的类应该先继承后实现接口

2、下列哪个对访问修饰符作用范围由大到小排列是正确的?

A、private>default>protected>public

B、public>default>protected>private

C、private>protected>default>public

D、public>protected>default>private

错误答案:B

正确答案:D

解析:这道题目实在不改错,平时应用default和protected权限的时候比较少

6decaed8b31ece9acfa93e85fde7571e.png

3、java接口的方法修饰符可以为?(忽略内部接口)

A、private

B、protected

C、final

D、abstract

错误答案:C

正确答案;D

解析:接口是一种特殊的抽象类,并且接口所有方法全是抽象方法只能 public abstract修饰 (默认public abstract修饰 ),属性默认public static final修饰。

抽象类除了包含抽象方法外与普通类无区别。

4、下列不属于Java语言性特点的是

A、Java致力于检查程序在编译和运行时的错误

B、Java能运行虚拟机实现跨平台

C、Java自己操纵内存减少了内存出错的可能性

D、Java还实现了真数组,避免了覆盖数据类型的可能

错误答案:C

正确答案:D

解析:注意,是避免数据覆盖的可能,而不是数据覆盖类型 ,真数组简介:

程序设计语言中,数组元素在内存中是一个接着一个线性存放的,通过第一个元素就能访问随后的元素,这样的数组称之为“真数组”。

实现了真数组为Java语言健壮性的特点之一。

5、以下代码将打印出

1 public static void main (String[] args) {

2 String classFile = "com.jd.". replaceAll(".", "/") + "MyClass.class";

3 System.out.println(classFile);

4 }

A、com. jd

B、com/jd/MyClass.class

C、///MyClass.class

D、com.jd.MyClass

错误答案:B

正确答案:C

解析:由于replaceAll方法的第一个参数是一个正则表达式,而"."在正则表达式中表示任何字符,所以会把前面字符串的所有字符都替换成"/"。如果想替换的只是".",那么就要写成"\\.".

6、设 a 是一个由线程 1 和线程 2 共享的初始值为 0 的全局变量,则线程 1 和线程 2 同时执行下面的代码,最终 a 的结果不可能是()

1

2 boolean isOdd = false;

3

4 for(int i=1;i<=2;++i)

5 {

6 if(i%2==1)isOdd = true;

7 else isOdd = false;

8 a+=i*(isOdd?1:-1);

9 }

A、-1

B、-2

C、0

D、1

错误答案:C

正确答案:D

解析:因为多线程存在值覆盖的情况,根据下图补充一下,第二种情景还有可能是-3,所以可能的值为-1,-2,0,-3

134d1b0f348429b75b630de12522a934.png

7、mysql数据库,game_order表表结构如下,下面哪些sql能使用到索引()?

2ae27298bd283faaee3cded923ad24bc.png

A、select * from game_order where plat_game_id=5 and plat_id=134

B、select * from game_order where plat_id=134 and

plat_game_id=5 and plat_order_id=’100’

C、select * from game_order where plat_order_id=’100’

D、select * from game_order where plat_game_id=5 and

plat_order_id=’100’ and plat_id=134

E、select * from game_order where plat_game_id=5 and plat_order_id=’100’

错误答案:ABCDE

正确答案:BCDE

解析:

这道题目想考察的知识点是MySQL组合索引(复合索引)的最左优先原则。最左优先就是说组合索引的第一个字段必须出现在查询组句中,这个索引才会被用到。只要组合索引最左边第一个字段出现在Where中,那么不管后面的字段出现与否或者出现顺序如何,MySQL引擎都会自动调用索引来优化查询效率。

根据最左匹配原则可以知道B-Tree建立索引的过程,比如假设有一个3列索引(col1,col2,col3),那么MySQL只会会建立三个索引(col1),(col1,col2),(col1,col2,col3)。

所以题目会创建三个索引(plat_order_id)、(plat_order_id与plat_game_id的组合索引)、(plat_order_id、plat_game_id与plat_id的组合索引)。根据最左匹配原则,where语句必须要有plat_order_id才能调用索引(如果没有plat_order_id字段那么一个索引也调用不到),如果同时出现plat_order_id与plat_game_id则会调用两者的组合索引,如果同时出现三者则调用三者的组合索引。

题目问有哪些sql能使用到索引,个人认为只要Where后出现了plat_order_id字段的SQL语句都会调用到索引,只不过是所调用的索引不同而已,所以选BCDE。如果题目说清楚是调用到三个字段的复合索引,那答案才是BD。

标签:牛客,id,错题,game,索引,答案,网刷题,plat,order

来源: https://www.cnblogs.com/fengyun2019/p/11167123.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值