Jack Huang's Blog


  • 首页

  • 标签

  • 归档

  • 搜索

金句摘抄

发表于 2022-12-16 | 更新于 2023-02-11

中国教材的最大问题,并不是知识点的讲解,而是缺乏得出结论的过程。

– 《为什么医学教材不好用?》

我不善于当众演讲,在人多的场合发言,我会紧张。但是后来,我发现听众真的不在乎,如果你讲得很糟糕,他们可能会发笑片刻,但很快就会忘记。

事实是我们放大了别人的想法。有人说的很对:我们在想象中比在现实中,遭受更多的痛苦。

– Hacker News 读者

参考链接

  1. GitHub 上这个「计算机科学」自学指南火了!,by 吴师兄.

软件行业的思考

发表于 2022-12-08

中国软件三十年:烟尘隐入,夹缝重生这篇文章对中国软件行业的历史、发展规律和现状认识比较深刻,因此摘抄一下:

中国软件的三大顽疾:一是企业数字化认识低,认为软件没用;二是定制化需求多且杂,「项目」导向而非「产品」导向;三是用户付费意愿和能力不足,软件公司难以积累利润投入研发。

大约是在2002年左右,雷军为了求证用户到底在意什么, 专门请了一家调查公司,在4个城市作了样本调查, 在4个城市作了用户专访, 最后结果让金山的工程师们很伤心:用户最在意的就是使用习惯,并不在意那些「创新」。

软件行业最终还是要靠「产品」说话。无论2C还是2B,软件好不好用,是用户选择最简单直接的一个标准。

参考链接

  1. 中国软件三十年:烟尘隐入,夹缝重生,by 饭统戴老板.

CPlusPlus之Socket网络编程

发表于 2022-12-07 | 更新于 2022-12-09

inet_pton和inet_ntop

这两个函数是随IPv6出现的函数,对于IPv4地址和IPv6地址都适用,函数中p和n分别代表表达(presentation)和数值(numeric)。地址的表达格式通常是ASCII字符串,数值格式则是存放到套接字地址结构的二进制值。

1
2
3
4
5
6
7
//将点分十进制的ip地址转化为用于网络传输的数值格式
//返回值:若成功则为1,若输入不是有效的表达式则为0,若出错则为-1
int inet_pton(int family, const char *strptr, void *addrptr);

//将数值格式转化为点分十进制的ip地址格式
//返回值:若成功则为指向结构的指针,若出错则为NULL
const char * inet_ntop(int family, const void *addrptr, char *strptr, size_t len);

参考链接

  1. C++高性能网络编程,by huangwang.
  2. inet_pton()和inet_ntop()函数详解,by QvQ是惊喜不是哭泣.
  3. 2021-07-07使用winsock2.h中函数还需要链接静态库ws2_32.lib,by 杨晴朗Solo.

游戏网络研究笔记

发表于 2022-11-14

游戏网络库

C / C++

  • ENet - 简单而强大的可靠 UDP 网络库。
  • GameNetworkingSockets - Valve 用于游戏的内部(Steam)网络传输层。
  • GGPO - 好游戏,Peace Out 回滚网络 SDK。
  • KCP - 一种快速可靠的 ARQ 协议。
  • RakNet - 功能齐全且成熟可靠的 UDP 网络引擎。
  • TNL2 -(非活动)扭矩网络库 2,与TRIBES 网络模型非常相似。
  • yojimbo - 用于具有专用服务器的客户端/服务器游戏的可靠 UDP 网络库。

参考链接

  1. Beginner’s Guide to Game Networking,by pvigier.
  2. GameNetworkingResources,by ThusSpokeNomad.
  3. Real Time Multiplayer in HTML5,by Sven Bergström.

Web打印方案

发表于 2022-10-31 | 更新于 2023-01-14

想在前端打印word文档,调研一下解决方案。

Vuejs解决方案

请参考记录超简单实现打印,window.print() 分页打印,vue element-ui window.print()打印。

print样式调试

请参考How do you debug printable CSS?。

打印页面样式设置

请参考css 打印print。

参考链接

  1. web打印,一篇搞定,by 俊劫​.
  2. window.print()打印样式不生效的问题,by 很远有多远.
  3. window.print() 前端页面打印与预览PDF,by 小何开发.
  4. window.print打印不全如何解决,by juejin.
  5. 关于@media print 的二三事..,by kakadodo.
  6. 记录超简单实现打印,window.print() 分页打印,vue element-ui window.print()打印,by 程序员李钟意.
  7. How do you debug printable CSS?,by stackoverflow.
  8. css 打印print,by 恬雅过客.

三分线构图方法

发表于 2022-10-28

参考链接

  1. 三分线构图,7种玩法,简单拍出美!,by 手机摄影构图大全.
  2. 常用的摄影构图之三分线,by 慢热氧气.
  3. 设计理论:如何使登录页更完美与高效?,by Lainey.
  4. ps制作设计网站登录界面,by 正在修炼web的小芮.

Vcpkg使用帮助

发表于 2022-10-26 | 更新于 2024-12-31

Vcpkg 可帮助您在 Windows、 Linux 和 MacOS 上管理 C 和 C++ 库。

安装vcpkg

首先,请下载vcpkg并执行 bootstrap.bat 脚本。

1
2
> git clone https://github.com/microsoft/vcpkg
> .\vcpkg\bootstrap-vcpkg.bat

使用vcpkg

使用以下命令安装您的项目所需要的库:

1
> .\vcpkg\vcpkg install [packages to install]

您也可以使用 search 子命令来查找vcpkg中集成的库:

1
> .\vcpkg\vcpkg search [search term]

若您希望在 Visual Studio 中使用vcpkg,请运行以下命令 (首次启动需要管理员权限)

1
> .\vcpkg\vcpkg integrate install

若您希望在 Visual Studio 中卸载vcpkg,请运行以下命令 (首次启动需要管理员权限)

1
> .\vcpkg\vcpkg integrate remove

卸载vcpkg只需删除vcpkg的文件夹即可。

导出开源库(通常在项目中使用第三方开源库时会把其拷贝到项目文件夹中使用):

1
vcpkg export spdlog:x64-windows --zip

然后将导出的开源库,放入另一台机器的vcpkg安装目录,即可使用。

参考链接

  1. Windows下OsgEarth编译安装过程,by huangwang.
  2. How to remove vcpkg and all libraries installed with vcpkg,by stackoverflow.
  3. [工具]包管理工具Vcpkg 的使用,by 南象.
  4. vs2017 + vcpkg包管理工具,by 爱看书的小沐.
  5. vcpkg安装库的导出和使用,by songjiahao.
  6. C++包管理工具vcpkg,by qqblack.

游戏AI开发方法

发表于 2022-10-19

现有游戏AI基本通过下面两个方式进行实现:行为树(Behavior Tree)与有限状态机(Finite State Machines)。

有限状态机

“状态机”是一种表示状态并控制状态切换的设计模式,常常用于设计某种东西的多个状态。而有限状态机是指游戏内的条件逻辑封装到各个状态类里。例如一个人有站立状态,跑动状态,走路状态,蹲下状态,开火状态等,当一个事件发生,将会触发一个动作,或者执行一次状态的迁移。

行为树

行为树是一棵用于控制 AI 决策行为的、包含了层级节点的树结构。树的最末端——叶子,就是这些 AI 实际上去做事情的命令;连接树叶的树枝,就是各种类型的节点,这些节点决定了 AI 如何从树的顶端根据不同的情况,来沿着不同的路径来到最终的叶子这一过程。

参考链接

  1. 游戏AI入门及AI优化,by 泪的天堂.
  2. AI 行为树的工作原理,by INDIENOVA.
  3. 游戏AI:AI的游戏还是游戏的未来,by Jim.
  4. 游戏AI之初步介绍,by KillerAery.

Vuejs中watch无法监听属性变化的问题

发表于 2022-10-14

vuejs的watch当值第一次绑定的时候,不会执行监听函数。可使用immediate:true解决。比如当父组件向子组件动态传值时,子组件props首次获取到父组件传来的默认值时,也需要执行函数,此时就需要将immediate设为true:

1
2
3
4
5
6
7
8
9
10
11
12
13
new Vue({
el: '#root',
data: {
cityName: ''
},
watch: {
cityName: {
  handler(newName, oldName) {
  // ...   },
  immediate: true
}
}
})

参考链接

  1. vue watch用法 及 immediate和handler,by Li同志103649.

Vuejs多窗口布局方法

发表于 2022-10-10 | 更新于 2022-10-11

Golden Layout 是一个 Javascript 布局管理器,它使您能够在网页中布局组件并通过拖放重新排列它们。

参考链接

  1. 以golden-layout官方网站版本,用vue2.x 开发的多布局管理,by 草莓沾奶豆腐.
  2. vue 启动报错:TypeError: Cannot read property ‘range‘ of null,by 进击de菜鸟.
  3. import实现动态路由时不能使用变量的问题,by 练习一下.
  4. golden layout version 1 doc,by golden-layout.
上一页1…121314…53下一页

Jack Huang

521 日志
67 标签
© 2025 Jack Huang
由 Hexo 强力驱动
|
主题 — NexT.Muse