OfferLimitedExceeded level
获赞
445
粉丝
134
关注
6
看过 TA
3810
华南理工大学
2025
C++
IP属地:广东
普通的大学生
私信
关注
后羿_houyi:关于问题5 可能出现了一些问题 这是我问GPT后得到的答案: 在多处理器系统中(如对称多处理系统 SMP 或分布式内存架构),处理器之间不能直接访问彼此的缓存,主要是因为以下几个原因: 缓存一致性: 每个处理器都有自己的缓存,这些缓存中存储的数据可能是不一致的。为了确保数据的一致性,需要有缓存一致性协议来管理多个处理器之间的数据更新。 如果允许一个处理器直接访问另一个处理器的缓存,那么可能会引入数据一致性问题,因为每个处理器可能看到的是不同的数据版本。 性能问题: 直接访问其他处理器的缓存通常比访问本地内存更慢。这是因为缓存访问依赖于高速缓存命中率,而直接跨处理器访问会增加延迟。 为了提高性能,系统设计时会尽量让每个处理器访问自己的缓存和本地内存。 架构限制: 多处理器系统的内存架构通常是基于节点的,每个节点包含一个或多个处理器以及本地内存。不同节点之间的通信通过互联网络进行,而不是直接访问对方的缓存。 可扩展性: 在大规模并行处理系统中,如果允许直接访问其他处理器的缓存,那么随着处理器数量的增加,缓存访问的复杂性和开销也会急剧增加,这会严重限制系统的可扩展性。 为了协调多处理器系统中的数据访问,并解决上述问题,现代多处理器系统使用了多种缓存一致性协议,例如 MESI (Modified, Exclusive, Shared, Invalid) 协议或其他变种。这些协议确保了所有处理器看到的内存是一致的,并且能够有效地管理缓存数据的状态。 也可以看一下这篇文章 https://cloud.tencent.com/developer/ask/sof/112244443
查看5道真题和解析
0 点赞 评论 收藏
分享
03-19 17:20
已编辑
华南理工大学 C++
好像部门有点缺人,准备了很多C++、Linux、OS、计网的八股,以前做的项目也记得滚瓜烂熟了,发现问的问题比较简单。部门是软开一面3.13 3.14上午通知已过二面3.15 当天下午通知已过三面主管面3.16 3.18上午通知已过,应该算OC了---------------一面(约70min,代码码的有点久)我对面试官最满意的一面(当然其他也很满意)面试官非常nice和细心,是第一个真的点进我简历里的项目github网址看过设计报告和代码才开始问的。而且非常平易近人哈哈。1. 问项目细节2. vector扩容3. 程序运行时堆和栈的区别4. malloc和new的区别5. 链表和vector的区别,vector删除某元素之后会发生什么行为,时间复杂度多少6. 进程和线程的区别7. 算法题:n个物品,刚好取k个,要求总重不能超过t,输出合法的总重。面试官提示:有非法输入:k>n我:一开始以为随便输出一个合法总重就行,转化为求前k小的问题。讲了可以用排序、堆、快速选择来做。面试官:看了眼样例,好像要求是输出我:直接暴力01背包,dp[i][j][l]表示到第i个物品,已经选了j个,总重为l是否存在。一维可以被压缩掉。i ---------------二面(30min?)1. 项目用户数据怎么存的2. 如果用数据库存该怎么做3. 项目为什么用到多态4. 项目中类封装的思路5. 指针和引用的区别6. 数组、链表、哈希表的区别7. 项目python爬虫怎么做的8. 项目用到什么设计模式相关的东西,为什么用这个9. 如果做python愿意转吗,是在大学城吗,可以随时到岗吗10. 算法题:括号匹配easy version,1min秒了---------------三面(两题均为15min,共30min)1. 手写Sqrt(double x)。没处理好0 2. 判断一个点是否在多边形内部。用的内角和≈360°,余弦定理暴力计算3. 多久能到岗 #软件开发2024笔面经#
0 点赞 评论 收藏
分享
03-08 20:57
已编辑
华南理工大学 C++
QQ浏览器后端开发这里是碎碎念:第三次面腾讯了。说实话因为接受5天4场面试的拷打,今天这场有点摆烂的心态。大概因为已经周五晚上了,面试官说面评会在下周给二面面试官看,让他决定能否通过。----------预定50min,结果答题+编程就只有30min,估计是没啥好问的,小崩。自我介绍(问的比较多,记不清了,以下为乱序面经)自己挑一个项目介绍。没有怎么深入去问C++ STL的数据结构了解哪些,算法呢接上文,sort()内部怎么实现的快排最好情况的时间复杂度多少(一开始答nlogn,结果对方问是否确定,犹豫了一下,心算了一下T(n) = 2T(n/2) + O(n)的递归表达式确定了是nlogn)快排的过程SQL索引有哪些unique索引的列是否可以为空值B+树和B树的区别为什么B+树效率更高Linux下怎么查看当前占用内存最高的进程哪些项目是Linux下做的,是否有自动生成.log日志的功能,有用Shell脚本去做什么吗,有用gdb调试吗算法题:判断链表是否回文。(事后查到是leetcode简单题,我没做过)先口述如何实现,然后写代码。口述的时候相当于脑袋里一下子蹦出来的做法:① 对链表节点建立索引,按索引访问(下一秒突然感到有点傻,ban掉了);② 两个指针i和j,i初始在头部,j递归到链表尾部,然后j随着回溯会自动往前走,i手动往后走。到写代码的第一秒改成双向链表做了......事后:不对啊按道理应该要限制用单向链表做,我自己diy了一个双向链表......不过面试官全程没什么意见就是了。----------反问(建议面试新手关注一下这个):因为我项目很单薄,于是问了面试官应该做哪些项目提升自己。面试官似乎不太在意,他建议无论是写项目还是技能,把自己最牛的多写点(精通),自己确实不行的少写点(了解),这样他也知道该问哪些东西,哪些问深点哪些问浅点。也就是说大家还是要实话实说,同时好好展示自己擅长的那一部分。
凉宫春:把自己最牛的多写点(精通),自己确实不行的少写点(了解),这样他也知道该问哪些东西,哪些问深点哪些问浅点。
0 点赞 评论 收藏
分享
关注他的用户也关注了:
牛客网
牛客企业服务