阿里云挑战赛

文章目录

  • 第一题
    • 题目:
    • 题解:
  • 第二题
    • 题目
    • 题解
  • 第三题
    • 题目
    • 题解
  • 第四题
    • 题目:
    • 题解
  • 第五题
    • 题目
    • 题解
  • 第六题
    • 题目
    • 题解
  • 第七题
    • 题目:
    • 题解
  • 第八题
    • 题目:
    • 题解;
  • 题解赛后出

第一题

题目:

【单选】filter 方法意图过滤传入的订单列表中不属于当前系统时间所在日期的订单,以下哪一行代码存在错误?

A.第 7 行
B.第 8 行
C.第 10 行
D.第 13 行


1.  public static void filter(ArrayList<Order> orders) {
2.     
3.     if (orders == null) {
4.         return;
5.     }
6.     
7.     SimpleDateFormat formatter = new SimpleDateFormat("YYYY-MM-dd")
8.     String currentDay = formatter.format(new Date());
10.    Iterator<Order> iterator = orders.iterator();
11.    while (iterator.hasNext()) {
12.        Order order = iterator.next();
13.        if (!currentDay.equals(order.getTransactionDay())) {
14.            iterator.remove();
15.        }
16.    } 
17.}

题解:

答案:A
获取当前时间

SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式
String date = formatter.format(new Date());// new Date()为获取当前系统时间,也可使用当前时间戳

【强制】日期格式化时,传入pattern中年份统一使用小写的y。
日期格式化时,yyyy表示当天所在的年,而大写的YYYY代表的是week in which year(JDK7之后引入的概念),意思是当天所在的周属于的年份,一周从周日开始,周六结束,只要本周跨年,返回的YYYY就是下一年。

第二题

题目

【单选】以下哪种字符串拼接方式,是效率最高、并符合阿里巴巴Java开发手册(Alibaba Java Coding Guidelines)规范的?

A.


public static String concat(List<String> strings) {if (strings == null || strings.isEmpty()) {return "";}StringBuilder builder = new StringBuilder();for (String string : strings) {builder.append(string);}return builder.toString();
}

B.


public static String concat(List<String> strings) {if (strings == null || strings.isEmpty()) {return "";}StringBuffer buffer = new StringBuffer();for (String string : strings) {buffer.append(string);}return buffer.toString();
}

C.


public static String concat(List<String> strings) {if (strings == null || strings.isEmpty()) {return "";}String result = strings.get(0);for (int i = 1; i < strings.length(); i++) {result = result + strings.get(i);}return result;
}

D.


public static String concat(List<String> strings) {if (strings == null || strings.isEmpty()) {return "";}return strings.stream().reduce((x, y) -> x + y).get();
}

题解

选C
【强制】在日志输出时,字符串变量之间的拼接使用占位符的方式。 说明:因为String字符串的拼接会使用StringBuilder的append()方式,有一定的性能损耗。使用占位符仅是替换动作,可以有效提升性能。 正例:logger.debug(“Processing trade with id: {} and symbol: {}”, id, symbol);

第三题

题目

【单选】以下哪段代码,调用 getHelper 的过程,不是线程安全的

A.


public class LazyInitDemo {private static Helper HELPER = null;public static synchronized Helper getHelper() {if (HELPER == null) {HELPER = new Helper();}return HELPER;}
}

B.


public class LazyInitDemo {private Helper helper = null;public Helper getHelper() {if (helper == null) {synchronized (this) {if (helper == null) {helper = new Helper();}}}return helper;}
}

C.


public class LazyInitDemo {  private static class HelperHolder {  private static final Helper HELPER = new Helper();  }  public static final Helper getHelper() {  return HelperHolder.HELPER; }  
}

D.


public class PreInitDemo{private static final Helper HELPER = new Helper();public static Helper getHelper(){return HELPER;}
}

题解

选B
【推荐】通过双重检查锁(double-checked locking)(在并发场景下)实现延迟初始化的优化问题隐患(可参考 The “Double-Checked Locking is Broken” Declaration),推荐解决方案中较为简单一种(适用于JDK5及以上版本),将目标属性声明为 volatile型(比如修改helper的属性声明为private volatile Helper helper = null;)。
反例:

public class LazyInitDemo {private Helper helper = null;public Helper getHelper() {if (helper == null) {synchronized (this) {if (helper == null) { helper = new Helper(); }}}return helper;}// other methods and fields...
}

第四题

题目:

【单选】 以下哪个选项的 getTypeString 函数,没有 bug?

A.


public class Type {public enum TypeEnum {ZERO,ONE}private TypeEnum type;public TypeEnum getType() {return type;}public void setType(TypeEnum type) {this.type = type;}public String getTypeString() {switch (type) {case ZERO:return "ZERO";case ONE:return "ONE";default:return "OTHER";}}
}

B.


public class Type {private String type;public String getType() {return type;}public void setType(String type) {this.type = type;}public String getTypeString() {switch (type) {case "0":return "ZERO";case "1":return "ONE";default:return "OTHER";}}
}

C.


public class Type {private int type;public int getType() {return type;}public void setType(int type) {this.type = type;}public String getTypeString() {switch (type) {case 0:return "ZERO";case 1:return "ONE";default:return "OTHER";}}
}

D.


public class Type {private Integer type;public Integer getType() {return type;}public void setType(Integer type) {this.type = type;}public String getTypeString() {switch (type) {case 0:return "ZERO";case 1:return "ONE";default:return "OTHER";}}
}

题解

选C
【强制】在一个switch块内,每个case要么通过continue/break/return等来终止,要么注释说明程序将继续执行到哪一个case为止;在一个switch块内,都必须包含一个default语句并且放在最后,即使它什么代码也没有。 说明:注意break是退出switch语句块,而return是退出方法体。
【强制】当switch括号内的变量类型为String并且此变量为外部参数时,必须先进行null判断。 反例:如下的代码输出是什么?

public class SwitchString {public static void main(String[] args) {method(null);}public static void method(String param) {switch (param) {// 肯定不是进入这里case "sth":System.out.println("it's sth");break;// 也不是进入这里case "null":System.out.println("it's null");break;// 也不是进入这里default:System.out.println("default");}}
}

【强制】在if/else/for/while/do语句中必须使用大括号。
说明:即使只有一行代码,禁止不采用大括号的编码方式:if (condition) statements;
2. switch 语句中的变量类型可以是: byte、short、int 或者 char。从 Java SE 7 开始,switch 支持字符串 String 类型了,同时 case 标签必须为字符串常量或字面量。

第五题

题目

【单选】执行:ln -sf /usr/sbin/sshd /tmp/su;/tmp/su -oPort=8888,执行完之后,任何一台机器ssh root@IP -p 8888,输入任意密码,成功登录。 问:该后门为什么能够任意密码登陆?

A. sshd 不指定配置文件启动时,所有账号均可任意密码登陆
B. sshd 因为被链接到/tmp目录,由于文件权限原因,可任意密码登陆
C. sshd 因为被链接为/tmp/su,由于pam模块认证原因,可任意密码登陆
D. sshd 因为被链接到/tmp目录,由于位置发生变化导致无法找到/etc/shadow文件因此放行登陆请求

题解

D

第六题

题目

【单选】\\.\globalroot\device\condrv\kernelconnect 在 Windows 中谷歌 Chrome 浏览器输入以上地址并回车可能会发生什么非预期的效果?

A. 浏览器崩溃
B. 成为阿里云锦鲤
C. 蓝屏
D. 黑屏

题解

选A

第七题

题目:

【不定项】以下哪种是 SQL 注入攻击?

A. content=1 union select 1
B. name=updatexml(1,user(),1)
C. id=i and 1 like 1
D. id=<script src="//bxssme.cn">

题解

AB
【强制】用户输入的SQL参数严格使用参数绑定或者METADATA字段值限定,防止SQL注入,禁止字符串拼接SQL访问数据库。
反例:某系统签名大量被恶意修改,即是因为对于危险字符 # --没有进行转义,导致数据库更新时,where后边的信息被注释掉,对全库进行更新。
【强制】sql.xml配置参数使用:#{},#param# 不要使用${} 此种方式容易出现SQL注入。

第八题

题目:

【不定项】以下哪种是 XSS 攻击?

A. id=confirm(1)
B. id=<img src=1 onerror=1>
C. id=<script>edoejx()</script>
D. content=1 and abs(2)

题解;

ABC

题解赛后出

我的答案:
A
C
B
C
D
A
AB
ABC
然后50分,卡死在第一关,哭死
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用C#编写STM32对接物联网平台IoTSharp发送遥测数据

在之前的文章中&#xff0c; 我们阐述了如何用C#在STM32上写第一个Hello world &#xff0c; 有朋友抱怨国内介绍文章&#xff0c; 都是一个 Hello world &#xff0c; 然后再也没有音讯&#xff0c; 写到这里我想提一下我的初心&#xff0c; 那就是告诉所有人C#无所不能&…

JavaMVC之JSON

JSON 8.1、什么是JSON&#xff1f; JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式&#xff0c;目前使用特别广泛。采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。易于人阅读和编写…

Java源文件声明规则

源文件声明规则: 当在一个源文件中定义多个类&#xff0c;并且还有import语句和package语句时&#xff0c;要特别注意这些规则。 一个源文件中只能有一个 public 类 一个源文件可以有多个非 public 类 源文件的名称应该和 public 类的类名保持一致。例如&#xff1a;源文件中…

Java内置数据类型

内置数据类型 Java语言提供了八种基本类型。六种数字类型&#xff08;四个整数型&#xff0c;两个浮点型&#xff09;&#xff0c;一种字符类型&#xff0c;还有一种布尔型。 byte&#xff1a; byte 数据类型是8位、有符号的&#xff0c;以二进制补码表示的整数&#xff1b; …

龙芯团队完成CoreCLR MIPS64移植,在github开源

国产龙芯的软件生态之中.NET不会缺席&#xff0c;毕竟 C# 与 .NetCore/Mono 也是全球几大主流的编程语言和运行平台之一&#xff0c;最近一段时间听到太多的鼓吹政务领域不支持.NET&#xff0c; 大家都明白这是某些人为了自己的利益打压使用.NET技术的公司&#xff0c;我今天写…

alibaba实习生代码大赛

文章目录题目Explanation代码&#xff08;此代码排名13&#xff0c;前十名有奖233333&#xff09;结果题目 在一个风雨交加的周末下午&#xff0c;大部分人都很不开心&#xff0c;因为出行不变&#xff0c;计划的娱乐活动都取消了&#xff0c;但菜鸟快递员小王却异常高兴&…

Java自动类型转换和强制类型转换(隐含)

自动类型转换 整型、实型&#xff08;常量&#xff09;、字符型数据可以混合运算。 运算中&#xff0c;不同类型的数据先转化为同一类型&#xff0c;然后进行运算。 转换从低级到高级。 低 ------------------------------------> 高 byte,short,char—> int —> …

来谈一谈专注力的真相

这是头哥侃码的第205篇原创在日常生活&#xff08;或工作&#xff09;中&#xff0c;你有没有遇上过这样的情况&#xff1f;比如你正在跟小伙伴讨论一个技术方案&#xff0c;聊着聊着&#xff0c;突然小A脑袋一抽筋&#xff0c;问你&#xff1a;“老大&#xff0c;咱们这周五晚…

成功陷阱有感

分享一下看到的关于成功陷阱的段落&#xff0c;关于成功陷阱&#xff0c;主要是最近面试字节跳动时&#xff0c;面试官向我推荐的&#xff0c;虽然也没有找到名叫《成功陷阱》的书&#xff08;后来发现书名应该是叫《能力陷阱》&#xff09;&#xff0c;但看了一些文章 最近听了…

Java访问控制修饰符

访问控制修饰符 Java中&#xff0c;可以使用访问控制符来保护对类、变量、方法和构造方法的访问。 Java 支持 4 种不同的访问权限。 default (即默认&#xff0c;什么也不写&#xff09;: 在同一包内可见&#xff0c;不使用任何修饰符。 使用对象&#xff1a;类、接口、变量…

数据结构与算法专题——第三题 最长公共子序列

一&#xff1a;作用最长公共子序列的问题常用于解决字符串的相似度&#xff0c;是一个非常实用的算法&#xff0c;作为码农&#xff0c;此算法是我们的必备基本功。二&#xff1a;概念举个例子&#xff0c;cnblogs这个字符串中子序列有多少个呢&#xff1f;很显然有27个&#x…

Java实现两个递增有序链表合并成一个递增有序链表和两个非递减有序链表合成一个非递增有序链表

代码如下: package sjjgniub;import java.util.LinkedList; import java.util.Scanner;SuppressWarnings("all") public class LinkList {private class Node{int data;Node next;public Node(){}public Node(int data){this.data data;next null;}}Node head nu…

职场PUA到底有多可怕?

阅读本文大概需要 5.2分钟。“小张&#xff0c;好好干啊&#xff0c;明年一定给你加薪&#xff01;” 。从小张入职这家公司起&#xff0c;这是老板对小张第三次这么说了。小张每天干到晚上12点&#xff0c;任劳任怨&#xff0c;虽然一直没涨过工资&#xff0c;但是老板的不断认…

SQL5 将查询后的列重新命名(数据库的几种去重方法)

牛客网题目 描述 题目&#xff1a;现在运营需要查看用户来自于哪些学校&#xff0c;请从用户信息表中取出学校的去重数据。 示例:user_profile 根据示例&#xff0c;你的查询应返回以下结果&#xff1a; 示例1 输入&#xff1a; drop table if exists user_profile; CREA…

数据结构与算法专题——第二题 优先队列

前段时间玩小爬虫的时候&#xff0c;我把url都是放在内存队列里面&#xff0c;有时我们在抓取url的时候&#xff0c;通过LCS之类的相似度比较&#xff0c;发现某些url是很重要的&#xff0c;需要后端解析服务器优先处理&#xff0c;针对这种优先级比较大的url&#xff0c;普通的…

SQL9 查找除复旦大学的用户信息(数据库否定语句写法)

描述 题目&#xff1a;现在运营想要查看除复旦大学以外的所有用户明细&#xff0c;请你取出相应数据 示例&#xff1a;user_profile 根据输入&#xff0c;你的查询应返回以下结果&#xff1a; 示例1 输入&#xff1a; drop table if exists user_profile; CREATE TABLE use…

SQL10 用where过滤空值练习

描述 题目&#xff1a;现在运营想要对用户的年龄分布开展分析&#xff0c;在分析时想要剔除没有获取到年龄的用户&#xff0c;请你取出所有年龄值不为空的用户明细数据。 示例&#xff1a;user_profile 根据输入&#xff0c;你的 查询应返回以下结果&#xff1a; 示例1 输入…

数据结构与算法专题——第一题 Bitmap算法

在所有具有性能优化的数据结构中&#xff0c;我想大家使用最多的就是hash表&#xff0c;是的&#xff0c;在定位查找场景上具有O(1)的常量时间&#xff0c;多么的简洁优美&#xff0c;但是在特定的场合下&#xff1a;①&#xff1a;对10亿个不重复的整数进行排序。②&#xff1…

Java阻止继承(sealed,permits)

阻止继承 正常情况下&#xff0c;只要某个class没有final修饰符&#xff0c;那么任何类都可以从该class继承。 从Java 15开始&#xff0c;允许使用sealed修饰class&#xff0c;并通过permits明确写出能够从该class继承的子类名称。 例如&#xff0c;定义一个Shape类&#xf…