选择/多选(就记得这么多了)线程同步机制下面是几种常见的线程同步的方式:互斥锁(Mutex):采用互斥对象机制,只有拥有互斥对象的线程才有访问公共资源的权限。因为互斥对象只有一个,所以可以保证公共资源不会被多个线程同时访问。比如 Java 中的 synchronized 关键词和各种 Lock 都是这种机制。读写锁(Read-Write Lock):允许多个线程同时读取共享资源,但只有一个线程可以对共享资源进行写操作。信号量(Semaphore):它允许同一时刻多个线程访问同一资源,但是需要控制同一时刻访问此资源的最大线程数量。屏障(Barrier):屏障是一种同步原语,用于等待多个线程到达某个点再一起继续执行。当一个线程到达屏障时,它会停止执行并等待其他线程到达屏障,直到所有线程都到达屏障后,它们才会一起继续执行。比如 Java 中的 CyclicBarrier 是这种机制。事件(Event) :Wait/Notify:通过通知操作的方式来保持多线程同步,还可以方便的实现多线程优先级的比较操作Mybatis当中的¥{} 和 # {}#{}方式能够很大程度防止sql注入(安全),${}方式无法防止Sql注入在JDBC能使用占位符的地方,最好优先使用#{}在JDBC不支持使用占位符的地方,就只能使用${},典型情况就是 动态参数#{}实现的是向prepareStatement中的预处理语句中设置参数值,sql语句中#{}表示一个占位符即?TCP协议lambda表达式的使用规则异常是不是对象?PreparedStatement和Statement的区别Statement:PreparedStatement:SpringBoot读取配置文件的注解@PropertySource,@Value,@Environment,@ConfigurationPropertiesnewInstance属于哪个类Java窗口函数关键字窗口函数是 SQL 中一类特别的函数。和聚合函数相似,窗口函数的输入也是多行记录。不 同的是,聚合函数的作用于由 GROUP BY 子句聚合的组,而窗口函数则作用于一个窗口, 这里,窗口是由一个 OVER 子句 定义的多行记录。聚合函数对其所作用的每一组记录输 出一条结果,而窗口函数对其所作用的窗口中的每一行记录输出一条结果。一些聚合函 数,如 sum, max, min, avg,count 等也可以当作窗口函数使用    1.聚合窗口函数许多常见的聚合函数也可以作为窗口函数使用,包括AVG()、SUM()、COUNT()、MAX()以及MIN()等函数。2.排名窗口函数排名窗口函数用于对数据进行分组排名,包括ROW_NUMBER()、RANK()、DENSE_RANK()、PERCENT_RANK()、CUME_DIST()以及NTILE()等函数。3.取值窗口函数取值窗口函数用于返回指定位置上的数据行,包括FIRST_VALUE()、LAST_VALUE()、LAG()、LEAD()、NTH_VALUE()等函数WEB输出值不完全可能会造成哪些漏洞?跨站脚本攻击(XSS)、跨站请求伪造(CSRF)、SQL注入、HTTP响应拆分、信息泄露、文件包含漏洞;编程题table(date, user_id, time)  (20230101, 1 , 2023-1-01 9-01- 00 00 00)找出各个用户一周的活跃天数:SELECT user_id, COUNT(DISTINCT DATE_FORMAT(time, '%Y-%m-%d')) AS active_daysFROM tableWHERE time >= DATE_SUB(CURDATE(), INTERVAL 1 WEEK)GROUP BY user_id;请 使用模板方法设计模式实现下面场景:A:巡查机房各服务器状态是否存在正常/异常B:巡查班级同学的出勤 远程视频检查完成后均需提交结果abstract class InspectionTemplate {    // 模板方法,定义了巡查的算法框架    public final void inspect() {        startInspection(); // 具体步骤1        checkStatus();     // 具体步骤2        submitResult();    // 具体步骤3    }    // 具体步骤1:开始巡查    protected abstract void startInspection();    // 具体步骤2:检查状态    protected abstract void checkStatus();    // 具体步骤3:提交结果    protected abstract void submitResult();}class ServerInspection extends InspectionTemplate {    // 具体实现步骤1:开始巡查服务器    @Override    protected void startInspection() {        System.out.println("开始巡查服务器状态...");    }    // 具体实现步骤2:检查服务器状态    @Override    protected void checkStatus() {        System.out.println("检查服务器状态是否正常/异常...");        // 具体的检查逻辑    }    // 具体实现步骤3:提交服务器巡查结果    @Override    protected void submitResult() {        System.out.println("提交服务器巡查结果...");        // 具体的提交逻辑    }}class ClassAttendanceInspection extends InspectionTemplate {    // 具体实现步骤1:开始巡查班级出勤    @Override    protected void startInspection() {        System.out.println("开始巡查班级同学的出勤...");    }    // 具体实现步骤2:远程视频检查    @Override    protected void checkStatus() {        System.out.println("远程视频检查同学的出勤情况...");        // 具体的检查逻辑    }    // 具体实现步骤3:提交出勤巡查结果    @Override    protected void submitResult() {        System.out.println("提交出勤巡查结果...");        // 具体的提交逻辑    }}public class TemplateMethodPatternExample {    public static void main(String[] args) {        // 巡查服务器状态        InspectionTemplate serverInspection = new ServerInspection();        serverInspection.inspect();        System.out.println();        // 巡查班级出勤        InspectionTemplate classAttendanceInspection = new ClassAttendanceInspection();        classAttendanceInspection.inspect();    }}三数之和public class threeSum {    public static void main(String[] args) {        int[] array = new int[]  {-1, 0, 1, 2, -1, -4};        for (int i =0 ; i < threesum(array).size(); i++) {            System.out.println(threesum(array).get(i));        }    }    public static List<List<Integer>> threesum(int[] numbers) {        // 1、首先对数组进行排序        List<List<Integer>> result = new ArrayList<List<Integer>>();        Arrays.sort(numbers);        // 2、对数据进行遍历        for (int i = 0; i < numbers.length; i++) {            // 因为是排好序的数组,所以i的值必须是小于0的            if (numbers[i] > 0) {                return result;            }            // 跳过重复值            if(i > 0 && numbers[i-1] == numbers[i]) {                continue;            }            // 设定双指针            int a = i + 1;            int b = numbers.length - 1;            while(a < b) {                if (numbers[i] + numbers[a] + numbers[b] < 0) {                    a++;                }else if (numbers[i] + numbers[a] + numbers[b] > 0) {                    b--;                } else {                    List<Integer> list = new ArrayList<>();                    list.add(numbers[i]);                    list.add(numbers[a]);                    list.add(numbers[b]);                    result.add(list);                    while(a < b && numbers[a + 1] == numbers[a]) a++;                    while(a < b && numbers[b - 1] == numbers[b]) b--;                    a++;                    b--;                }            }        }        return result;    }}
点赞 15
评论 8
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务