八股文(C#篇)
C#中的数值类型
堆和栈
值类型的数据被保存在栈(stack)上,而引用类型的数据被保存在堆(heap)上,当值类型作为参数传递给函数时,会将其复制到新的内存空间中,因此在函数中对该值类型的修改不会影响原始值类型。
拆箱和装箱是什么
装箱是指将值(int double)类型转换为对应的引用(object)类型,从内存角度上来说是将栈中的内容迁移到堆上
拆箱就是把引用转成值类型,把堆中的内容转移到栈上去
int i=3;
objcet o=i;//装箱
i=(int)o //拆箱
值和引用类型在变量赋值时的区别是什么?
值类型变量赋值会创建一个新的拷贝,而引用类型变量赋值会创建一个新的引用指向同一个对象。
委托和事件在使用上的区别是什么?
事件相对与委托来说,事件在外部使用时只能使用+= -=
有两个接口IA和IB,他们中有一个同名方法Test()
一个类同时继承这两个接口,应该如何处理他们的同名方法?
显式实现接口
IA.Test()
IB.Test()
在C#中数据类型分为值类型和引用类型
值类型:结构体、枚举
引用类型:类、接口、数组、委托
请说明C#中的List是如何扩容的
当 List 需要扩容时,它会创建一个新的更大的内部数组,并将现有元素复制到新数组中,然后使用新数组替换旧数组
请说说你认为C#中 == 和 Equals 的区别是什么?
Equals继承自Object,一般用于比较对象内容是否相等,而==在不重载的前提下如果是值类型更倾向于比较值是否相等,引用倾向于比较地址是否相等,运算效率也不同,Equals比较的内容多,所以效率会差一点
浅拷贝和深拷贝的区别?可以举例说明
浅拷贝只拷贝指针(C++)引用(C#),拷贝完的数据修改了原数据也会修改,但是深拷贝就是拷贝了一份新的,修改并不会影响原数据
上面两种获10000个数的方式,哪种效率更高?为什么
方式2:因为List会不断扩容,扩容时会反复拷贝造成性能损耗
请说出以下代码AB谁先打印,AB打印的值分别为多少
void Start(){int i=GetInt();Debug.Log("第A处 i= "+i);}static int GetInt(){int i=10;try{return i;}finally{i=11;Debug.Log("第B处 i= "+i);}}
不论try块中的代码是否抛出异常,finally块中的代码都会被执行
先输出B=11然后输出A=10
public class CsharpLearing : MonoBehaviour
{void Start(){Test t=GetObj();Debug.Log("第A处 i= "+t.i);}static Test GetObj(){Test t=new Test();try{return t;}finally{t.i=11;Debug.Log("第B处 i= "+t.i);}
}
}class Test{public int i=10;
}
这里和上面不一样,先输出B=11,然后输出A=11
这两段程序输出不同的原因是因为Getint返回的是值类型,而getObj返回的是引用类型
泛型的约束有哪几种
- 值类型约束
- 引用类型约束
- 公共无参数构造函数
- 类约束
- 接口约束
- 另一个泛型约束
什么是闭包?举例说明
闭包是指有权访问另一个函数作用域中变量的函数(用lambda或匿名方法实现,可以捕获不属于其作用域的值)
C#中内存泄漏
- 静态引用:如果一个静态对象长时间存活且占用大量内存,并且该对象不会被释放或重置,可能导致内存泄漏
- 不使用的引用对象没有置null
- 委托或事件没有解除注册
请说明字符串中
string str = null
string str = “”
string str = string.Empty
三者的区别
-
str = null 在堆中没有分配内存地址
-
str = “” 和 string.Empty 一样都是在堆内存中分配了空间,里面存储的是空字符串
-
string.Empty是一个静态只读变量
对string和StringBuilder我们应该如何选择
string是不可变的,意味着一旦创建了字符串对象,就无法更改其内容。任何对字符串的修改都会创建一个新的字符串对象。线程更安全
StringBuilder是可变的,可以通过对其进行操作来修改其内容,而不必创建新的对象。这使得在需要频繁修改字符串时,使用StringBuilder比使用string更高效。线程不安全
string在每次拼接时都会产生垃圾
而StringBuilder在拼接时,是在原空间中进行修改,不会产生垃圾,会自动帮助我们扩容
所以当字符串需要频繁修改拼接时,我们使用StringBuilder
.Net跨语言原理
.Net制定了了CLI公共语言基础结构的规则
只要是按照该规则设计的语言在进行.Net相关开发时
编译器会将源代码(C#、VB等等)编译为CIL通用中间代码。
也就是说不管什么语言进行开发,最终都会统一规范变为中间代码
最终通过CLR(公共语言运行时或者称为.Net虚拟)将中间代码翻译为对应操作系统的原生代码(机器码)
在操作系统(Windows)上运行
C# 中的Action和Func是什么?Unity 中的UnityAction是什么?他们有什么区别?
Action和Func是System命名空间下 C#为我们提供的两个写好的委托
Action本身是一个无参无返回值的委托
对应的Action<>泛型委托支持最多16个参数
Func本身是一个无参有返回值的委托
对应的Func<>泛型委托支持最多16个参数,并且有返回值
UnityAction是UnityEngine.Events命名空间下 Unity为我们提供的写好的委托
UnityAction本身是一个无参无返回值的委托
对应的UnityAction<>泛型委托支持最多4个参数
程序阅读
public void Dosomething (A a){a.id=6;a.name="Bob";a.children[0]=7;}void Start(){var a=new A();a.name="Alick";a.children=new int[]{1,2,3};Dosomething(a);Debug.Log(a.name+a.id+a.children[0]);}
输出Alick07
请问以上这三行代码,运行后,在堆上会分配几块内存
两块
"123"一块
"1234"一块
C#中如何让一个类不能再被其他类所继承?
使用密封关键字sealed修饰该类
C#中使用泛型的好处是什么?
1.可以为不同类型对象的相同行为进行通用处理,提升代码复用率
2.避免装箱拆箱,提升性能
C#中元组对于我们的作用是什么?
可以在不用写数据结构类的情况下
利用元组处理多返回值,或者临时数据的集合
请简述GC(垃圾回收)产生的原因,并至少说出避免GC发生的三种方式?
GC产生的原因是 避免堆内存溢出而产生的回收机制
当不再使用的堆内存占用达到一定上限时,将会进行垃圾回收
避免方式:
1.尽量减少new对象,尽量复用对象(可使用缓存池)
2.用StringBuilder替换String,避免字符串拼接时产生垃圾
3.公共对象用静态声明
如果我们想为Unity中的Transform类添加一个自定义的方法,应该如何处理?
通过C#的拓展方法相关知识点进行添加
请说出using关键字的两个作用
1.引入命名空间
2.安全使用引用对象
C#中Dictionary不支持相同键存储如果想要一个键对应多个值如何处理?
程序阅读
全是10:当委托最终执行时,他们使用的i,都是for循环中声明的i,此时的i已经变成了10
如果我想要输出1~10怎么办
使用一个临时变量接当前值
内存抖动指什么?
内存抖动指短时间内有大量的对象被创建或者被回收的现象
频繁的内存抖动会造成 GC 频繁运行,造成卡顿
C#中new关键字的作用(至少说出3种)
- 创建新对象
- 子类函数声明时加上new关键字,可以隐藏掉父类方法
- 泛型约束时使用new关键字表示需要无参构造
回调函数指什么?一般在什么时候使用?(至少说出3种使用场景)
- 异步编程:异步逻辑执行完毕后,再执行回调函数
- 事件中心
- UI界面中的空间逻辑回调,比如按钮点击
csharp里面有一个常用的接口叫做IDispose,它的作用是?
IDispose接口是 C# 中用于手动释放资源的机制
通过显式调用 Dispose() 方法来实现资源的释放,避免资源泄漏和浪费
它允许对象在不再需要时显式地释放资源,而不依赖于垃圾回收器的自动内存管理
csharp有垃圾回收机制,把一个对象设置为空的时候,系统会帮我们回收,它和接口IDispose有什么关系吗?为什么会存在两个做析构事情的东西呢?
C#中的垃圾回收机制,只会回收托管堆上分配的对象。
对于非托管资源以及其它需要显示释放的资源,垃圾回收是无法自动处理的,因为这些资源不属于托管堆,因此垃圾回收器无法自动识别和回收。这种情况下我们就需要显示的手动释放这些资源了。
而IDispose接口就提供了一种通用的机制来进行资源清理,主要用于释放非托管资源。
非托管资源:
- 文件句柄,在操作系统中打开的文件等
- 数据库链接,与数据库服务器简历的链接
- 网络链接:比如Socket的连接对象
- unsafe关键词中使用的指针
属性和字段
属性一般可以用来封装字段
属性相对字段来说,属性具有封装性,允许对字段进行封装,提供更多的控制和逻辑。
相比直接访问字段来说,属性允许我们在字段访问的过程汇总添加验证、计算等逻辑
属性还可以在其中对set和get设置不同的访问级别,使得字段的读取和写入可以收到更精细的控制
抽象类中的虚函数和抽象函数,是否必须在子类中重写?
虚函数的重写是可选的,当需要在子类中修改逻辑时可以选择重写
抽象函数必须重写
里氏替换
当我们使用里式替换原则,用父类容器装载子类对象时
我们通过该父类容器调用其中的一个虚函数,执行的逻辑是父类中的还是子类中的逻辑呢?
Father Eat
Son :Father
Son EatFather f = new Son();
f.Eat();
- 若子类没有重写虚函数,那么执行的逻辑会是父类中的逻辑
- 若子类重写了虚函数,那么执行的逻辑会是子类中的逻辑(是否执行父类中逻辑,主要看子类重写时是否利用了base执行父类逻辑)
C#使用var声明临时变量相比用指定变量类型声明临时变量,在最终执行时是否会增加性能消耗?
var i = 10;
float f = 5.5f;
不会,var在编译时会被推断为正确的类型,所以在运行时不会引入额外的性能开销。
相当于在编译阶段var就会被翻译为指定的类型。
var声明临时变量只会影响代码的可读性和可维护性(双刃剑)
我们可以使用C#中的迭代器来做什么?至少说出两点
- foreach
- 协同程序
工厂模式在游戏开发中一般用来做什么
对象实例化
对于需要频繁创建的对象,比如角色、敌人、道具、特效、音效等等,工厂模式可以将实例化逻辑封装到一个工厂类中,提供统一方法给外部调用
C#中如何在函数中返回多个返回值?(至少说出3种方法)
- 数组等容器
- 结构体或类自定义数据结构
- out参数
- 元组
int[,] strArray = new int[3, 4]这个语句创建了多少个int对象?string[,] strArray = new string[3, 4]这个语句创建了多少个string对象?
12个,0个
避免装箱拆箱的方案有哪些?
- 用泛型
- 使用里氏替换原则
什么是闭包,为什么说闭包可能会带来内存泄漏?
闭包可能会捕获并持有外部作用域变量的引用。
这些引用会导致外部作用域的对象持续存在,即使它们不再需要。
C#中在字符串前面加一个@符号或者$符号有什么作用
@符号:让转义字符失效
$符号:插值字符串,可以在字符串中加入 {变量名} 插入变量值
C#中提供了序列化和反序列化2进制数据的公共类BinaryFormatter为什么我们一般还要自己去实现序列化和反序列化2进制数据的方法?
- BinaryFormatter跨平台方面不好
- 自己写更容易进行加密处理
- 节约空间,BinaryFormatter会包含一些除数据以外的额外信息
异或加密的原理是什么?请简要说明
异或加密是一种简单的对称加密算法。原理就是基于异或运算,相同为0,不同为1。
异或加密时会有一个固定的密钥
想要加密的数据与该密钥进行异或运算得到加密后的数据
加密后的数据再和密钥进行异或运算得到原数据(解密后的数据)
举例:
假设原数据为:1010
密钥为:1100
加密后的数据为:1010^1100 = 0110
解密数据:0110^1100 = 1010
程序阅读
public Father<Father<int>> Test()
{return new Son<Son<int>>();
}
这个写法是否正确?
不正确,会报错
因为Son<Son>并不是Father<Father>的子类型
如果要修改
我们可以返回
return new Son<Father>();
C#类中的函数是否占用内存空间?
占用,但是它不再我们通常说的堆栈中
而是存储在内存中的文本段(Text Segment)
它是存储可执行程序的代码的内存段
C#中的函数是何时被加载到内存中的呢?
CLR(公共语言运行时)会按需加载程序集和其中的类型和成员
程序执行到需要调用某个类的函数时
CLR 会负责将该函数的 IL 代码编译成本机代码
并将其加载到 Text Segment 中
一旦函数的代码被加载到内存中,它通常会一直存在于内存中,直到程序退出
C#函数中一般会声明一些临时变量,当函数被加载内存中后,所占的内存空间是否包含函数中的这些临时变量?
不会包含。
函数中的临时变量,不管是值类型还是引用类型都是在函数执行期间动态分配的。
这些临时变量会在堆栈中进行内存分配
栈上的内存由CLR动态管理,用完会被销毁
堆上的内存有GC垃圾回收机制统一进行管理
C#中委托的本质是什么?它是如何存储函数的?
委托的本质是一个类,当我们声明一个委托时,相当于声明了一个类。
它会默认继承System.MulticastDelegate类(多播委托类)
而这个System.MulticastDelegate类 又继承Delegate类(委托类)
这些父类当中的一些方法,就是当我们对委托进行操作时真正会调用的内容
通过这些父类中的方法我们其实可以简单推测出
委托中存储函数的本质,是通过一个委托类对象来存储对象的引用或者静态类的类型
然后再记录一个函数的名字。
但是实际上,在内部会根据这些信息定位到
1.函数的引用(函数的内存地址)
2.函数所在对象的引用(如果是实例方法)
而当我们进行 += 操作时,其实C#内部会调用父类中的Combine结合方法
在底层帮助我们声明一个新的委托对象来记录对应函数的相关信息
C#中事件的本质是什么?
我们在使用事件的时候往往是在类中声明成员变量时
当我们声明一个事件时,本质就是对委托进行私有访问限制的封装
事件的本质其实就是委托
C#中如何在函数中返回多个返回值?(至少说出3种方法)
- 数组等容器
- 结构体或类自定义数据结构
- out参数
- 元组
抽象类中的虚函数和抽象函数,是否必须在子类中重写?
子类中
虚函数的重写是可选的,当需要在子类中修改逻辑时可以选择重写
抽象函数必须重写
当我们使用里式替换原则,用父类容器装载子类对象时
我们通过该父类容器调用其中的一个虚函数,执行的逻辑是父类中的还是子类中的逻辑呢?
Father Eat
Son :Father
Son EatFather f = new Son();
f.Eat();
- 若子类没有重写虚函数,那么执行的逻辑会是父类中的逻辑
- 若子类重写了虚函数,那么执行的逻辑会是子类中的逻辑(是否执行父类中逻辑,主要看子类重写时是否利用了base执行父类逻辑)
C#使用var声明临时变量相比用指定变量类型声明临时变量,在最终执行时是否会增加性能消耗?
不会,var在编译时会被推断为正确的类型,所以在运行时不会引入额外的性能开销。
相当于在编译阶段var就会被翻译为指定的类型。
C#中属性(Property)和字段(Field)的区别是什么?
属性一般可以用来封装字段
属性相对字段来说,属性具有封装性,允许对字段进行封装,提供更多的控制和逻辑。
相比直接访问字段来说,属性允许我们在字段访问的过程汇总添加验证、计算等逻辑
属性还可以在其中对set和get设置不同的访问级别,使得字段的读取和写入可以收到更精细的控制
Unity Shader中,深度测试是在做什么?
深度测试用于确定哪些像素应该被绘制到屏幕上,并决定它们的可见性。
深度测试的主要目标是解决遮挡关系,确保前面的对象覆盖后面的对象,从而正确呈现场景
Unity Shader中某片元通过了深度测试,但是没有开启深度写入,该片元的颜色信息是否写入到颜色缓冲区?
会写入颜色缓冲区
因为深度写入和颜色写入是两个独立的操作
只要通过了深度测试,不管是否写入深度缓冲区
该片元的颜色信息都会写入到颜色缓冲区中
C#中在什么情况下会选择使用接口,什么情况下会选择使用抽象类?
接口:
1.不同对象的共同行为
2.需要多继承时
抽象类:
1.同类对象的共同行为
2.共享成员变量
C#托管内存都有哪些
比如我们平时声明的 unsafe语句块中的指针成员,数据库链接对象,Socket通讯对象,文件流等对象都存在非托管内存,需要我们自己释放
C#中new关键字的作用(至少说出3种)
- 创建新对象
- 子类函数声明时加上new关键字,可以隐藏掉父类方法
- 泛型约束中使用new关键词,表示需要无参构造
相关文章:

八股文(C#篇)
C#中的数值类型 堆和栈 值类型的数据被保存在栈(stack)上,而引用类型的数据被保存在堆(heap)上,当值类型作为参数传递给函数时,会将其复制到新的内存空间中,因此在函数中对该值类型的修改不会影…...
【YOLOv9算法原理简介】
YOLOv9算法原理 单阶段检测器:YOLOv9延续了YOLO系列的单阶段检测器设计,即在单次前向传播中同时预测边界框和类别概率,这使得它能够实现快速的检测速度。通用高效层聚合网络(GELAN) :YOLOv9引入了一种新的模型架构GELAN,它通过高效的层聚合块和计算模块,以较小的参数量…...

2010NOIP普及组真题 2. 接水问题
线上OJ: 一本通:http://ybt.ssoier.cn:8088/problem_show.php?pid1950 解法一、朴素模拟 核心思想: 朴素模拟: 1、先给每个b[i]水龙头分配一个人a[i],b[i] 表示水龙头的剩余时间。同时标记该水龙头为 used 使用中 2…...

ElementUI从unpkg.com完整下载到本地的方法 - 解决unpkg.com不稳定的问题 - 自建镜像站 - 不想打包只想cdn一下
方法 方法1)随便弄个文件夹,根据官网npm方法下载包,提取即可 npm i element-ui -S cd /node_modules/element-ui/ ls src 安装npm方法:https://nodejs.org/en 方法2)不推荐 - 在github中搜索对应的库zip包࿰…...
什么是BFF API
BFF(Backend For Frontend)API 是一种架构模式,旨在为特定的前端应用(如移动应用、桌面应用或网页应用)提供定制化的后端服务。通过这种方式,后端可以根据前端的具体需求和特性,提供最优化的数据…...

分享自己一篇在亚马逊云科技AWS官网发的Blog技术文章
小李哥在亚马逊AWS官网,作为第一作者发了自己的第一篇AWS Blog文章,也是自己今年在AWS官网的第11篇文章。文章主要内容是描述为出海的金融企业,搭建满足PCI-DSS合规、FIPS 140-2 Level 3安全标准的传输中数据加密云端方案,主要用于…...
封装长按触发事件的uniapp组件
简单说一下原理 首先介绍三个针对触摸屏设备的事件,分别是: touchstart:当手指触摸屏幕时触发,即触摸开始的时候;touchend:当手指离开屏幕时触发,即触摸结束的时候;touchcancel&am…...

Docker 安装的MySQL迁移数据库
1. 导出数据库 docker ps :查看数据库对应的 CONTAINER ID docker exec -it id /bin/bash : 进入到mysql的docker实例中 cd /usr/bin : 进入到bin目录 mysqldump -u root -p123456 study > /root/study_backup0509.sql :使用mysqldump备份库,注意密码与-p之间…...
算法训练Day28 | ● 122.买卖股票的最佳时机II ● 55. 跳跃游戏 ● 45.跳跃游戏II
122.买卖股票的最佳时机II class Solution { public:int maxProfit(vector<int>& prices) {vector<int> dp(2,0);dp[0] -prices[0];for(int i1; i<prices.size(); i){dp[0] max(dp[0], dp[1]-prices[i]);dp[1] max(dp[1], prices[i]dp[0]);}return dp[1]…...

Linux(openEuler、CentOS8)基于chrony企业内网NTP服务器搭建实验
一、知识点 chrony 是由 守护进程 chronyd 以及 命令行工具 chronyc 组成的 chronyd 在后台静默运行并通过 123 端口与时间服务器定时同步时间,默认的配置文件是 /etc/chrony.conf chronyc 通过 323 端口与 chronyd 交互,可监控 chronyd 的性能并在运…...

前端开发框架Vue
版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl Vue概述 Vue.js(简称Vue)是由尤雨溪(Evan You)创建并维护的一款开源前端开发框架。Vue以其轻量级、易上手和高度灵活的特点&…...
Vue2中引入ElementUI
Vue中引入ElementUI 目录 Vue中引入ElementUI安装 全库导入main.py使用 仅引入样式文件main.py使用 安装 官方文档 npm i element-ui -S全库导入 main.py import ElementUI from element-ui;Vue.use(ElementUI)使用 <template> <div class"main">&l…...

华中科技大学雷达站部署
一:项目地址 GitHub - HUSTLYRM/HUST_Radar_2023: 华中科技大学狼牙战队 RoboMaster 2023赛季 雷达站 二:安装依赖 2.1创建虚拟环境 首先是程序是基于python3.8完成,所以创建虚拟环境的时候,选择3.8的虚拟环境 conda create -…...

小程序引入 Vant Weapp 极简教程
一切以 Vant Weapp 官方文档 为准 Vant Weapp 官方文档 - 快速入手 1. 安装nodejs 前往官网下载安装即可 nodejs官网 安装好后 在命令行(winr,输入cmd)输入 node -v若显示版本信息,即为安装成功 2. 在 小程序根目录 命令行/终端…...

labview技术交流-将时间字符串转换成时间格式
应用场景 我们在数据库中设计了datetime类型的字段,比如字段名就叫“保存时间”,当我们使用labview将表中数据读取出来后datetime类型的数据是以字符串的格式显示的。而我们想计算两条数据“保存时间”的间隔时间时,用字符串类型自然是没法计…...
算法提高之迷宫问题
算法提高之迷宫问题 核心思想:最短路问题 从(n-1,n-1)开始bfs 往前走一个就存入pre数组 之后再遍历pre数组输出 #include <iostream>#include <cstring>#include <algorithm>using namespace std;const int N 1010,M N*N;#define x first#def…...

泛微E9开发 通过点击按钮来复制选择的明细行
泛微E9开发 通过点击按钮来复制选择的明细行 复制明细行功能背景展示效果实现方法 复制明细行 功能背景 用户可以通过“复制明细”按钮来实现新增选择的明细行,并且新增明细行的数据跟选择的数据完全一样,具体操作如下图所示: 手动新增明细…...

sqlalchemy 分表实现方案
1.需求及场景概述 现有系统中因历史数据量过大,产生了将历史数据进行按月存储的要求,系统和数据库交互使用的是sqlalchemy,假设系统的原来的历史记录表(record)如下: 为了将历史数据按月分表存储࿰…...
QML进阶(十五) QML各种标准元素的用法
文章目录 文本图像控件TextTextInputTextFieldTextEditTextAreaImage按钮控件ButtonRadioButtonCheckBoxComboBox进度控制控件ProgressBarSlider...
【工具使用】快速实现Makefile模板的方法
一,简介 我们在使用gcc编译程序时,常常需要自己实现Makefile,那么如何快速的实现Makefile呢?这里把一些基本的操作整理成模板,供参考。 二,模板介绍 功能包含基本功能编译exe(包括调用其他算…...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...

《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...
今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存
文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...
Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?
在大数据处理领域,Hive 作为 Hadoop 生态中重要的数据仓库工具,其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式,很多开发者常常陷入选择困境。本文将从底…...
现有的 Redis 分布式锁库(如 Redisson)提供了哪些便利?
现有的 Redis 分布式锁库(如 Redisson)相比于开发者自己基于 Redis 命令(如 SETNX, EXPIRE, DEL)手动实现分布式锁,提供了巨大的便利性和健壮性。主要体现在以下几个方面: 原子性保证 (Atomicity)ÿ…...

GitFlow 工作模式(详解)
今天再学项目的过程中遇到使用gitflow模式管理代码,因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存,无论是github还是gittee,都是一种基于git去保存代码的形式,这样保存代码…...

LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案
在移动互联网营销竞争白热化的当下,推客小程序系统凭借其裂变传播、精准营销等特性,成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径,助力开发者打造具有市场竞争力的营销工具。 一、系统核心功能架构&…...