0%

SVM的函数间隔定义中会用到点到超平面距离的推导,《统计学习方法》中对此没有详细的解释,当然这个问题有许多解法,找到了一种比较直观的解法如下。

QuickSort 快速排序是常见的考察代码基本功面试题。简洁易读的实现可以一定程度展现面试者的代码功底。

算法导论对于快排讲解的很透彻,也有伪代码,即便如此,网上许多实现还是错的,不能通过一些边界用例,如数组已排序或数组中有重复元素的情况。还有一些用python的实现不满足原位排序(in-place)的要求,直接新建两个新List,这种方法其实也是取巧,简化了partition函数的实现难度。

Google Ads是许多独立博客赢利维持自身运转的方案之一。不过近些年前已经不大流行了,因为转化率低,没有很大的基础流量支持,其实很难赚到钱。独立博客的流量如果不做PR的话,主要还是靠搜索引擎。而提升流量的根本需要有对应的用户群,相较而言,微信公众号、头条号上的平台流量足够大,用户粘度更高,赢利方式也更为多样,对作者来说更易变现。现在这年头还玩独立博客的人,我想都是有一份自己的坚持,一块独立的领地,完全自由掌控的感觉,想靠这个赚钱还是算了。

kubernetes dashborad是用来查看cluster各项指标的Web UI。但是直到目前依然不支持用户级别的语言设置。它默认根据浏览器的语言设置作为自己的界面语言,这样对于中文Chrome用户来说略有不便:k8s dashboard作为一个管理工具,由于需要中文反译回英文,严重影响了工作效率。感受一下中文界面:

最近爬取几个页面总是失败,遇到如下错误:

1
# The HTTP request to the remote WebDriver server for URL http://localhost:xxx/ session timed out after 60 seconds.

后来发现原因是页面加载缓慢,debug发现页面其实已经在浏览器中成功渲染,只是还在等待一些后台javascript加载完毕,然后超时报错。

如果一个interface或abstract method的参数为基类形参,而有另一个类实现了该interface,但却使用了派生类形参,会发生什么?或者考虑另一种情况,一个interface或abstract method的返回值为基类对象,而它的实现返回的却是派生类对象,会发生什么?

2023-01-30 更新: NexT主题已经支持相关文章功能 (使用 hexo-related-posts ),更新到最新版本即可,可参考 这里


Hexo的NexT主题展示相关文章和热门文章使用 hexo-related-popular-posts 插件,但hexo-related-popular-posts 默认展示位置是在页面底部,而页面底部本身内容较多,多数人注意不到相关文章。因此,考虑将相关文章展示在侧边栏。

大概五、六年前看过一个很逗的开封话图解趣谈,形象生动。文章结合了北宋时期包公日常对话的题材,很是风趣幽默。 今日与友人谈起想找下原贴发现找不到了,搜到的几个贴子中链接大多已失效。有趣的内容不可负也,这里转载备份一份以飨众人~

今天先聊聊static方法的那些事儿,然后再引出static使用的“极致” util/helper类,说说它们的问题。

static方法什么时候用?

简单说在面向对象的场景下,绝大多数情况都不应使用static方法。这里有一些关于static使用场景的讨论: When should I use static methods?

事情源起于心血来潮把Hexo从v3.9.0升级到了v4.0.0,Hexo本身的升级倒是不难,它由npm管理,改下package.json,运行npm update即可。但之后发现在archives的分页显示有问题……

计算机圈中有些常见被中国人读错的单词,现列举部分如下:

AJAX

/'eɪdʒæks/,不读阿假克斯。

ASCII

/'æski/,不读[ask]。

cache

/kæʃ/,不读[catch]。

有这样的一个interface:

1
2
3
4
public interface Filter
{
    IList<string> Filter(IList<string> responses)
}

在实现它时,如果过滤后没有结果,返回null还是new List()?

一段流水线处理代码

先看下面一段流水线处理的内部方法,即GenerateCandidates(), FilterA()和FilterB()都没有用户输入等边界:

Unity是一个.NET Framework用于依赖注入的容器。依赖注入一般分为三个阶段:Register, Resolve和Dispose。Unity支持三种方式的Register:

使用Unity的InjectionFactory进行依赖注入遇到如下提示:

‘InjectionFactory’ is obsolete: ‘InjectionFactory has been deprecated and will be removed in next release. Please use IUnityContainer.RegisterFactory(…) method instead.

提示InjectionFactory将被淘汰的注入代码:

在代码库里看到不少Task.ContinueWith()的代码,查了下语法,没太理解下面两种写法的区别(借用MSDN的代码):

1
2
3
4
5
6
7
8
public static async Task ContinueWithExample()
{
    // Execute the antecedent.
    Task<DayOfWeek> taskA = DayOfWeekAsync();

    // Execute the continuation when the antecedent finishes.
    await taskA.ContinueWith(antecedent => Console.WriteLine("Today is {0}.", antecedent.Result));
}
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
public static async Task AwaitExample()
{
    DayOfWeek dayOfWeek = await DayOfWeekAsync();
    Console.WriteLine("Today is {0}.", dayOfWeek);
}

public static async Task<DayOfWeek> DayOfWeekAsync()
{
    Console.WriteLine("Enter DayOfWeekAsync()");
    await Task.Delay(500);
    return DateTime.Today.DayOfWeek;
}

await与ContinueWith的区别

标题有些标题党,但实际上await是continuewith的替代者,是一种更先进和简洁的语法。

AIMD (additive-increase/multiplicative-decrease)是用于TCP拥塞控制的算法。AIMD思想虽然简单,但我认为它非常符合“simple but elegant”的哲学。尤其是在多连接拥塞控制中的公平性分析,还挺巧妙。这里主要探讨AIMD在非TCP场景下的应用,不对其原理进行深度剖析。

Crawler运行一段时间后可能会莫名其妙地停止工作,查看日志发现如下错误:

1
session not created: This version of ChromeDriver only supports Chrome version 76

原因是用selenium创建ChromeDriver时,ChromeDriver与ChromeBrowser的版本不匹配(这玩意儿兼容性看起来不是很好),而此问题总是发生的原因在于ChromeBrowser会自动升级,因此需要手动将ChromeDriver也升级到对应版本。

卤煮火烧是一道地道的北京小吃,如果你爱吃内脏,那它必定是你不能错过的美味; 反之则是吾之蜜糖,彼之砒霜,唯恐避之不及。其实许多北京小吃还是挺好吃的,只是术业有专攻,吃每样小吃得找对店铺,自然得花些功夫。加之街头许多店挂羊头卖狗肉,打着名吃的旗号却做不出那个味儿,大部分人尤其是游客只想尝个鲜,随口一吃就下了结论“这东西真难吃”,殊不知只是没找对地方。而许多景点又有太多所谓小吃一条街,表面看来方便了食客将美食一“街”打尽,实际却砸了招牌,几无回头客。