达闼面试(部分)(未完全解析)

news/2024/11/28 17:51:52/
  • grpc怎么解决负载均衡问题? Answer by newBing : gRPC提供了多种负载均衡策略,包括轮询、随机、最少连接数等。gRPC客户端可以使用这些策略来选择要连接的服务器。
    k8s环境下部署grpc的几种方案 : 在k8s环境中,可以选择headless service,或者基于Etcd/consul 等外部服务注册中心。这两种方案都是客户端负载均衡。

    • 客户端是只和一个server建立连接,还是和所有server建立连接?相关知识:grpc客户端会和一个server建立HTTP2长连接。
  • 有没有基于Spring做过二次开发?

  • 你对多态是怎么理解的?Java实现多态的原理是什么?即把父类引用指向子类对象,当调用方法时,系统为什么能找到正确的方法?知道虚函数表的作用吗?相关知识:动态绑定:

细究一下Java的动态绑定机制(非常重要) :

运行时绑定也叫动态绑定,它是一种调用对象方法的机制。Java调用对象方法时,一般采用运行时绑定机制。
当调用对象属性时,没有动态绑定机制。

如果方法是private、static、final或者构造器,编译器就可以确定调用那个方法。这是静态绑定
如果不是上述情况,就要使用运行时(动态)绑定。

百度百科:动态绑定 :

动态绑定是多态性得以实现的重要因素,它通过方法表来实现:每个类被加载到虚拟机时,在方法区保存元数据,其中,包括一个叫做方法表(methodtable)的东西,表中记录了这个类定义的方法的指针,每个表项指向一个具体的方法代码。如果这个类重写了父类中的某个方法,则对应表项指向新的代码实现处。

我们假设Fatherft=newSon();ft.say();Son继承自Father,重写了say()。
在代码的编译阶段,编译器通过声明对象的类型(即引用本身的类型)在方法区中该类型的方法表中查找匹配的方法(最佳匹配法:参数类型最接近的被调用),如果有则编译通过。(这里是根据声明的对象类型来查找的,所以此处是查找Father类的方法表,而Father类方法表中是没有子类新增的方法的,所以不能调用。)

ft.say()调用的是Son中的say(),这里就是动态绑定机制的真正体现。
而在实际运行这条语句时,在执行Fatherft=newSon();这一句时创建了一个Son实例对象,然后在ft.say()调用方法时,JVM会把刚才的son对象压入操作数栈,用它来进行调用。
子类中如果重写了父类的方法,则方法表中同名表项会指向子类的方法代码;若无重写,则按照父类中的方法表顺序保存在子类方法表中。

  • 了解Go语言吗

  • 了解linux的进程空间的内存布局吗?Answer by newBing : Linux进程空间的内存布局一般可以粗略地分为以下几大段,从高内存到低内存排列:代码段text、数据段data、bss段、堆、栈和内核数据区(命令行参数和环境变量等)。其中,代码段text通常是只读的,数据段data和bss段通常是可读写的,堆和栈则是动态分配的.

  • volatile的原理。volatile禁止的是谁的指令重排序?Answer by newBing : volatile关键字禁止的是编译器CPU对指令序列进行重排序。Q:内存屏障起的什么作用?相关知识1

内存屏障(memory barrier)是一个CPU指令。基本上,它是这样一条指令: a) 确保一些特定操作执行的顺序; b) 影响一些数据的可见性(可能是某些指令执行后的结果)。

常见的内存屏障有以下几种:

a. 通过 Synchronized关键字包住的代码区域,当线程进入到该区域读取变量信息时,保证读到的是最新的值.这是因为在同步区内对变量的写入操作,在离开同步区时就将当前线程内的数据刷新到内存中,而对数据的读取也不能从缓存读取,只能从内存中读取,保证了数据的读有效性.这就是插入了StoreStore屏障
b. 使用了volatile修饰变量,则对变量的写操作,会插入StoreLoad屏障. 
c. 其余的操作,则需要通过Unsafe这个类来执行.

附:本博的一些相关讨论:
如何理解synchronized的可见性?
volatile的可见性探讨
synchronized、指令重排序、有序性

  • git reset --hard命令恢复到了之前的一次commit,如果查询之前的HEAD?相关知识:git reflog :

2git log shows the current HEAD and its ancestry …
git reflog … is an ordered list of the commits that HEAD has pointed to: it’s undo history for your repo.

3git reflog 可以查看所有分支的所有操作记录(包括已经被删除的 commit 记录和 reset 的操作):
在这里插入图片描述


  1. java内存屏障的原理与应用 ↩︎

  2. Stackoverflow : What’s the difference between git reflog and log? ↩︎

  3. git命令log与reflog的比较 ↩︎


http://www.ppmy.cn/news/978045.html

相关文章

单片机第一季:零基础11——实时时钟DS1302

目录 1,DS1302 时钟芯片介绍 2,BCD码介绍 3,涉及到的寄存器 3.1,控制寄存器 3.2,日历/时钟寄存器 3.3,DS1302 的读写时序 4,相关代码 这一章我们来学习DS1302 时钟芯片&#xff0c…

openGauss学习笔记-20 openGauss 简单数据管理-DISTINCT

文章目录 openGauss学习笔记-20 openGauss 简单数据管理-DISTINCT20.1 语法格式20.2 参数说明20.3 示例 openGauss学习笔记-20 openGauss 简单数据管理-DISTINCT DISTINCT关键字与SELECT语句一起使用,用于去除重复记录,只获取唯一的记录。 当一个表中有…

APP自动化测试工具大全

在本篇文章中,将给大家推荐14款日常工作中经常用到的测试开发工具神器,涵盖了自动化测试、APP性能测试、稳定性测试、抓包工具等。 【B站最通俗易懂】Python接口自动化测试从入门到精通,超详细的进阶教程,看完这套视频就够了 一、…

Angular:动态依赖注入和静态依赖注入

问题描述: 自己写的服务依赖注入到组件时候是直接在构造器内初始化的。 直到看见代码中某大哥写的 private injector: Injector 动态依赖注入和静态依赖注入 在 Angular 中,使用构造函数注入的方式将服务注入到组件中是一种静态依赖注入的方式。这种方…

sql关键字和字段冲突

问题描述:包含key字段名的条件查询sql语句执行居然报错 select * from goods_table where key"apple";执行报错: 报错原因 sql语句的字段和关键字发生冲突,导致无法解析sql 报错解决 key加反引号后,即可解决 sele…

本地 IDC 中的 K8s 集群如何以 Serverless 方式使用云上计算资源

作者:庄宇 在前一篇文章《应对突发流量,如何快速为自建 K8s 添加云上弹性能力》中,我们介绍了如何为 IDC 中 K8s 集群添加云上节点,应对业务流量的增长,通过多级弹性调度,灵活使用云上资源,并通…

Java Spring和Spring集成Mybatis

0目录 1.Spring 2.Spring集成Mybatis 1.Spring 特性 IOC:控制反转 AOP:面向切面 Spring组成部分 在SMM中起到的作用(粘合剂) Spring理念 OOP核心思想【万物皆对象】 Spring核心思想【万物皆Bean组件】 Spring优势 低侵入式 …

React.memo高阶组件

1、概念 React.memo 为高阶组件。 如果你的组件在相同 props 的情况下渲染相同的结果,那么你可以通过将其包装在 React.memo 中调用,以此通过记忆组件渲染结果的方式来提高组件的性能表现。这意味着在这种情况下,React 将跳过渲染组件的操作并…