Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
醒狮指南
JavaGuide
提交
7a2c17d5
J
JavaGuide
项目概览
醒狮指南
/
JavaGuide
与 Fork 源项目一致
从无法访问的项目Fork
通知
5
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
JavaGuide
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7a2c17d5
编写于
3月 08, 2021
作者:
G
guide
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of github.com:Snailclimb/JavaGuide
上级
78b1b307
7ae5f4bc
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
6 addition
and
13 deletion
+6
-13
docs/java/jvm/类加载过程.md
docs/java/jvm/类加载过程.md
+1
-1
docs/system-design/website-architecture/关于大型网站系统架构你不得不懂的10个问题.md
...stem-design/website-architecture/关于大型网站系统架构你不得不懂的10个问题.md
+1
-1
docs/tools/Github技巧.md
docs/tools/Github技巧.md
+4
-11
未找到文件。
docs/java/jvm/类加载过程.md
浏览文件 @
7a2c17d5
...
...
@@ -62,7 +62,7 @@ Class 文件需要加载到虚拟机中之后才能运行和使用,那么虚
解析阶段是虚拟机将常量池内的符号引用替换为直接引用的过程。解析动作主要针对类或接口、字段、类方法、接口方法、方法类型、方法句柄和调用限定符7类符号引用进行。
符号引用就是一组符号来描述目标,可以是任何字面量。
**直接引用**
就是直接指向目标的指针、相对偏移量或一个间接定位到目标的句柄。在程序实际运行时,只有符号引用是不够的,举个例子:在程序执行方法时,系统需要明确知道这个方法所在的位置。Java 虚拟机为每个类都准备了一张方法表来存放类中所有的方法。当需要调用一个类的方法的时候,只要知道这个方法在方
发
表中的偏移量就可以直接调用该方法了。通过解析操作符号引用就可以直接转变为目标方法在类中方法表的位置,从而使得方法可以被调用。
符号引用就是一组符号来描述目标,可以是任何字面量。
**直接引用**
就是直接指向目标的指针、相对偏移量或一个间接定位到目标的句柄。在程序实际运行时,只有符号引用是不够的,举个例子:在程序执行方法时,系统需要明确知道这个方法所在的位置。Java 虚拟机为每个类都准备了一张方法表来存放类中所有的方法。当需要调用一个类的方法的时候,只要知道这个方法在方
法
表中的偏移量就可以直接调用该方法了。通过解析操作符号引用就可以直接转变为目标方法在类中方法表的位置,从而使得方法可以被调用。
综上,解析阶段是虚拟机将常量池内的符号引用替换为直接引用的过程,也就是得到类或者字段、方法在内存中的指针或者偏移量。
...
...
docs/system-design/website-architecture/关于大型网站系统架构你不得不懂的10个问题.md
浏览文件 @
7a2c17d5
...
...
@@ -24,7 +24,7 @@
### 1. 你使用过哪些组件或者方法来提升网站性能,可用性以及并发量
1.
**提高硬件能力、增加系统服务器**
。(当服务器增加到某个程度的时候系统所能提供的并发访问量几乎不变,所以不能根本解决问题)
2.
**使用缓存**
(本地缓存:本地可以使用JDK自带的 Map、Guava Cache.分布式缓存:Redis、Memcache.本地缓存不适用于提高系统并发量,一般是用
处用
在程序中。比如Spring是如何实现单例的呢?大家如果看过源码的话,应该知道,S把已经初始过的变量放在一个Map中,下次再要使用这个变量的时候,先判断Map中有没有,这也就是系统中常见的单例模式的实现。)
2.
**使用缓存**
(本地缓存:本地可以使用JDK自带的 Map、Guava Cache.分布式缓存:Redis、Memcache.本地缓存不适用于提高系统并发量,一般是用在程序中。比如Spring是如何实现单例的呢?大家如果看过源码的话,应该知道,S把已经初始过的变量放在一个Map中,下次再要使用这个变量的时候,先判断Map中有没有,这也就是系统中常见的单例模式的实现。)
3.
**消息队列**
(解耦+削峰+异步)
4.
**采用分布式开发**
(不同的服务部署在不同的机器节点上,并且一个服务也可以部署在多台机器上,然后利用 Nginx 负载均衡访问。这样就解决了单点部署(All In)的缺点,大大提高的系统并发量)
5.
**数据库分库(读写分离)、分表(水平分表、垂直分表)**
...
...
docs/tools/Github技巧.md
浏览文件 @
7a2c17d5
...
...
@@ -90,19 +90,13 @@ Github 前段时间推出的 Codespaces 可以提供类似 VS Code 的在线 IDE
这个网站会提供一个类似 VS Code 的在线 IDE。
## 6. 一键开启 Github 夜间模式
通过
**GitHub Dark Theme**
这个 Chrome 插件你可以将 Github 的主题变为夜间样式。
![](
https://guide-blog-images.oss-cn-shenzhen.aliyuncs.com/2020-11/image-20201107160240274.png
)
## 7. 扩展 Github 的功能
## 6. 扩展 Github 的功能
**Enhanced GitHub**
可以让你的 Github 更好用。这个 Chrome 插件可以可视化你的 Github 仓库大小,每个文件的大小并且可以让你快速下载单个文件。
![](
https://guide-blog-images.oss-cn-shenzhen.aliyuncs.com/2020-11/image-20201107160817672.png
)
##
8
. 自动为 Markdown 文件生成目录
##
7
. 自动为 Markdown 文件生成目录
如果你想为 Github 上的 Markdown 文件生成目录的话,通过 VS Code 的
**Markdown Preview Enhanced**
这个插件就可以了。
...
...
@@ -110,7 +104,7 @@ Github 前段时间推出的 Codespaces 可以提供类似 VS Code 的在线 IDE
![](
<
https://guide-blog-images.oss-cn-shenzhen.aliyuncs.com/2020-11/iShot2020-11-07%2016.14.14%20(1).png
>
)
##
9
. 后记
##
8
. 后记
这篇文章是我上周六的时候坐在窗台写的,花了一下午时间。
...
...
@@ -118,4 +112,4 @@ Github 前段时间推出的 Codespaces 可以提供类似 VS Code 的在线 IDE
除了我提到的这些技巧之外,像 Github 搜索技巧、GitHub Actions 等内容的话,我这里没有提,感兴趣的小伙伴自行研究一下。
这里多说一句心里话:
**Github 搜索技巧不必要记网上那些文章说的各种命令啥的,真没啥卵用。你会发现你用的最多的还是关键字搜索以及 Github 自带的筛选功能。**
\ No newline at end of file
这里多说一句心里话:
**Github 搜索技巧不必要记网上那些文章说的各种命令啥的,真没啥卵用。你会发现你用的最多的还是关键字搜索以及 Github 自带的筛选功能。**
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录