谢谢,已修复 typo。
如果是 IPv6 连接的话,应该会涉及到
DNS4 | DNS6 | |
---|---|---|
IPv4 | DNS4 + IPv4 | DNS6 + IPv4 |
IPv6 | DNS4 + IPv6 | DNS6 + IPv6 |
这么一个 2x2 的问题。可以先用 https://ipv6-test.com/ 这网站确认自己 IPv6 是正常工作的。看解析出来的 2409:8c54::/32 确实是中国移动机房的地址,像是一个合理的 CDN 节点,不过我这里 IPv6 肯定是好的的情况下打过去也是 100% 丢包。
可以可以,我安排一下。
std::bad_alloc
是 C++ 内存申请失败的异常吧。申请失败的常见原因应该是... 你机器上内存已经被吃爆掉了,分配不出可用内存了?
乐理还是讲相对关系,标准音高其实是可以变的,调律方式也是可以变的。所以我只是用了其中一种比较常用的来写了,毕竟写代码最好还是确定算法确定数值比较好处理一点。
Sonic Pi 我也用过,算是可以很方便用 Ruby 来为合成器进行编程。特别是现在高级的合成器按钮越来越多,真的还不如直接弄个 DSL 来写比较方便。
其实本来是想在线下的分会场弄一个小的 workshop 尝试的。但现在搬到线上后,互动性没有那么强了,是有点直播 coding 的味道了。
差不多比起 Keynote 演讲的纯介绍性,更多地加入 Live Coding 来演示某一种技术的使用。以练习和 tutorial 为主,内容不一定需要太先进或困难。
促进一下生态,我又花了一天写了个 PetriNet 的可视化编辑器 https://github.com/dsh0416/petri-editor
花了两天时间简单写了个 DSL https://github.com/dsh0416/petri-dsl/
用法:
require 'petri'
network = Petri::Net.new do |net|
net.start_place :start, name: 'Start'
net.end_place :end, name: 'End'
net.transition :leader_evaluate, name: 'Leader Evaluate', consume: :start do |t|
t.produce :leader_approved, name: 'Leader Approved', with_guard: :approved
t.produce :rejected, name: 'Rejected', with_guard: :rejected
end
net.transition :hr_evaluate, name: 'HR Evaluate', consume: :leader_approved do |t|
t.produce :hr_approved, name: 'HR Approved', with_guard: :approved
t.produce :rejected, with_guard: :rejected
end
net.transition :report_back, name: 'Report Back', consume: :hr_approved, produce: :end
net.transition :resend_request, name: 'Resend Request', consume: :rejected do |t|
t.produce :start, with_guard: :resend
t.produce :end, with_guard: :discard
end
end
puts network.compile
# {:places=>[{:label=>:start, :name=>"Start"}, {:label=>:end, :name=>"End"}, {:label=>:leader_approved, :name=>"Leader Approved"}, {:label=>:rejected, :name=>"Rejected"}, {:label=>:hr_approved, :name=>"HR Approved"}], :transitions=>[{:label=>:leader_evaluate, :name=>"Leader Evaluate", :consume=>[:start], :produce=>[{:label=>:leader_approved, :guard=>:approved}, {:label=>:rejected, :guard=>:rejected}]}, {:label=>:hr_evaluate, :name=>"HR Evaluate", :consume=>[:leader_approved], :produce=>[{:label=>:hr_approved, :guard=>:approved}, {:label=>:rejected, :guard=>:rejected}]}, {:label=>:report_back, :name=>"Report Back", :consume=>[:hr_approved], :produce=>[{:label=>:end, :guard=>nil}]}, {:label=>:resend_request, :name=>"Resend Request", :consume=>[:rejected], :produce=>[{:label=>:start, :guard=>:resend}, {:label=>:end, :guard=>:discard}]}], :start_place=>:start, :end_place=>:end}
大概可以相对方便地来描述 workflow 了。
我觉得维护一个 OpenCV 的 wrapper 可能先得维护一个线性代数库,返回一个 Array,甚至是 Array 的 Array 的 Array 还是有点蠢的,而且很难处理。ruby 现在有内建的 Matrix 库,不知道能不能堪此大任。
我比较好奇「帮包装」是个什么流程
RubyGems 的下载量会把镜像下载也统计进去,1k 以下的参攷意义不是很大。另外,这让我嗅到了一股 leftpad 的味道。。。
翻译自 https://www.ruby-lang.org/en/news/2019/12/25/ruby-2-7-0-released/
我们很高兴宣布 Ruby 2.7 已发布。
此版本引入了大量新特性和性能提升,其中最值得注意的是:
在函数式编程中非常常用的模式匹配功能,作为实验性功能被加入了。功能 #14912 它可以遍历一个对象,并在其满足某一模式时进行赋值。
case JSON.parse('{...}', symbolize_names: true)
in {name: "Alice", children: [{name: "Bob", age: age}]}
p age
...
end
关于更多信息,请查阅 Pattern matching - New feature in Ruby 2.7。
irb
,集成的交互环境 (REPL; Read-Eval-Print-Loop),现已支持多行编辑,由 reline
(一个 readline
兼容的库)实现了纯 Ruby 的支持。它还提供 rdoc 集成。在 irb
中您可以为指定的类、模块或方法的显示引用。功能 #14683、功能 #14787、功能 #14918 此外,Binding.irb
中显示的代码和核心类的检查结果现在已经可以彩色呈现。
此版本引入了 Compaction GC,可以对内存空间碎片进行整理。
某些多线程 Ruby 程序会导致内存碎片化,进而导致内存占用率提高和速度降低。
我们引入了 GC.compact
方法来压缩堆。此函数能压缩堆中的存活对象,以更少地占用内存分页。并且堆可能会变得对写入时复制(CoW)更友好。
功能 #15626
关键词参数和位置参数的自动转换被标记为已废弃(deprecated),自动转换将会在 Ruby 3 中被移除。[功能 #14183]
请查看文章 "Separation of positional and keyword arguments in Ruby 3.0" 来了解详情,下面仅叙述变更之处。
def foo(key: 42); end; foo({key: 42}) # warned
def foo(**kw); end; foo({key: 42}) # warned
def foo(key: 42); end; foo(**{key: 42}) # OK
def foo(**kw); end; foo(**{key: 42}) # OK
def foo(h, **kw); end; foo(key: 42) # warned
def foo(h, key: 42); end; foo(key: 42) # warned
def foo(h, **kw); end; foo({key: 42}) # OK
def foo(h, key: 42); end; foo({key: 42}) # OK
def foo(h={}, key: 42); end; foo("key" => 43, key: 42) # warned
def foo(h={}, key: 42); end; foo({"key" => 43, key: 42}) # warned
def foo(h={}, key: 42); end; foo({"key" => 43}, key: 42) # OK
def foo(opt={}); end; foo( key: 42 ) # OK
def foo(**kw); p kw; end; foo("str" => 1) #=> {"str"=>1}
**nil
被允许使用在方法定义中,用来标记方法不接受关键词参数。以关键词参数调用这些方法会抛出 ArgumentError [功能 #14183]
def foo(h, **nil); end; foo(key: 1) # ArgumentError
def foo(h, **nil); end; foo(**{key: 1}) # ArgumentError
def foo(h, **nil); end; foo("str" => 1) # ArgumentError
def foo(h, **nil); end; foo({key: 1}) # OK
def foo(h, **nil); end; foo({"str" => 1}) # OK
h = {}; def foo(*a) a end; foo(**h) # []
h = {}; def foo(a) a end; foo(**h) # {} and warning
h = {}; def foo(*a) a end; foo(h) # [{}]
h = {}; def foo(a) a end; foo(h) # {}
如果你希望禁用废弃警告,请使用命令行参数 -W:no-deprecated
,或把 Warning[:deprecated] = false
加入你的代码。
ary[..3] # identical to ary[0..3]
rel.where(sales: ..100)
Enumerable#tally
,它会计算每个元素出现的次数。["a", "b", "c", "b"].tally
#=> {"a"=>1, "b"=>2, "c"=>1}
self
上调用私有方法 [功能 #11297] [功能 #16123]
def foo
end
private :foo
self.foo
Enumerator::Lazy#eager
。它会产生一个非懒惰的迭代器。[功能 #15901]
a = %w(foo bar baz)
e = a.lazy.map {|x| x.upcase }.map {|x| x + "!" }.eager
p e.class #=> Enumerator
p e.map {|x| x + "?" } #=> ["FOO!?", "BAR!?", "BAZ!?"]
JIT [实验性质]
--jit-min-calls
的默认值从 5 调整到 10,000。--jit-max-cache
的默认值从 1,000 调整到 100。Fiber 的缓存策略发生了改变,从而提升了其创建速度。 GH-2224
Symbol#to_s
, Module#name
, true.to_s
, false.to_s
和 nil.to_s
现在始终返回一个冻结(frozen)字符串。返回的字符串始终和给定的对象相等。 [实验性] [功能 #16150]
CGI.escapeHTML
的性能被提升了。GH-2226
Monitor 和 MonitorMixin 的性能被提升了。[功能 #16255]
1.9 中引入的 Per-call-site 方法缓存的性能提升了。缓存的命中率从 89% 提升到了 94%。详见 GH-2583
RubyVM::InstructionSequence#to_binary 方法会编译出二进制,二进制的尺寸被进一步缩小了。[功能 #16163]
一些标准库已被更新
下面这些库不再是自带 gem,如需使用请安装他们。
profile.rb
从标准库中被移除。
将下面的标准库提升至默认 gems
在方法调用中使用没有代码块的 Proc.new
和 proc
现在会抛出警告。
在有代码块的方法调用中使用没有代码块的 lambda
会抛出异常。
Unicode 和 Emoji 版本从 11.0.0 更新至 12.0.0。[功能 #15321]
更新 Unicode 至 12.1.0 版本,新增对于新年号「令和」U+32FF 的支持。[功能 #15195]
Date.jisx0301
、Date#jisx0301
和 Date.parse
支持新的日本年号。[功能 #15742]
编译器需要支持 C99 [杂项 #15347] *关于我们使用方言的具体信息请查阅:https://bugs.ruby-lang.org/projects/ruby-trunk/wiki/C99
圣诞快乐,节日快乐,享受使用 Ruby 2.7 编程吧!
Ruby 是最初由 Matz(Yukihiro Matsumoto)于 1993 年开发,现在作为开源软件开发的语言。它可以在多个平台上运行,并在世界各地使用。尤其适合于网站的开发。
刚交了简体中文的翻译 PR
参攷 2.6.0 Release News 的性能提升章节
$SAFE
临时赋值的支持,提升 Proc#call
的速度。[功能 #14318]
通过 lc_fizzbuzz
多次使用 Proc#call
的 benchmark 我们测量到了 1.4 倍性能提升 [漏洞 #10212]。
block
是代码块参数时 block.call
的性能。[功能 #14330]
通过与 Ruby 2.5 中引入的提升代码块传递的性能的方法结合,Ruby 2.6 进一步提升了传递代码块调用时的性能。通过 micro-benchmark 我们观察到了 2.6 倍性能提升。[功能 #14045]
瞬态堆是用于管理指向特定类(Array、Hash、Object 和 Struct)短生命周期内存对象的堆。例如,创建小而短生命周期的哈希对象的速度提升到了 2 倍快。根据 rdoc benchmark,我们观察到了 6% 到 7% 的性能提升。
arm32
、arm64
、ppc64le
、win32
、win64
、x86
、amd64
)显著提升了 Fiber 的性能。 [功能 #14739]
Fiber.yield
与 Fiber#resume
方法在 64 位 Linux 上提升了 5 倍性能。对于使用 Fiber 密集的程序,约有最高 5% 的性能提升。
这些提升都不是 JIT 带来的,Ruby 2.0 以来的每个大版本都有类似的性能优化。
装个旧版本的 Virtualbox,再在里面跑 Linux(逃
这个基本上和财务数据的逻辑是一致的,是一个类似单向 (qu) 链 (kuai) 表 (lian) 的结构。中间有一个节点变化,至少会引起之后所有的数据都必须要重算。最坏的情况是变更第一个值,就不得不触发全表重建。
这样的查询适合单独存一张表吧,否则的话,每次做一定是扫全表,时间复杂度是 O(n+m),放在数据库里做好像没有什么意义啊。
还是没懂,你要不要列一下计算过程
是说 A 的 id
是主键,B 的 id
是 A 的外键。然后 n 是初始值,m 是每次 action 的消耗。d 返回经过每次消耗后的剩余的集合?
不知道为什么我一访问 Edit Profile 页面就直接 302 回主页了,看来等会要回报 bug。
在关注 AutoFiber 和 Guild 的发展情况。。。如果 AutoFiber 被实现得很好的话就没什么价值了。如果 AutoFiber 有一些问题,特别是现在可能和 Guild 冲突。而 Midori 可以依赖 Guild 实现更复杂的多核异步模型的话,速度会再快几倍。但现在这俩玩意的状态我也看不太懂,所以也不知道怎么弄了。。。
可以直接看 Homeland 的具体 Schema 实现。
源代码放出来只是让你看,并不能让你用。就像别人放在那里的芒果,你不能寻思是别人不要了吧。
代码是不是开源,需要取决于使用什么授权协议。哪怕是 GPL 的 RedHat 也有卖商业服务的。
如果人家没有设定任何授权协议的话,那就只能默认是 Copyright 私有了。
中央声称会优化,至于会不会就要看之后有没有相关的 patch 了。
看了下 Rest Client 的 API,后面还是作为 Hash 参数传进去的,只是因为 Post 前面多了个参数,所以被传错地方了。于是多传一个 nil 进去就好了。
require 'rest-client'
require 'json'
r = RestClient.post('https://httpbin.org/post', nil, params: {foo: 'bar', baz: 'qux'})
JSON.parse(r.body)
# => {"args"=>{"baz"=>"qux", "foo"=>"bar"}, "data"=>"", "files"=>{}, "form"=>{}, "headers"=>{"Accept"=>"*/*", "Accept-Encoding"=>"gzip, deflate", "Connection"=>"close", "Content-Length"=>"0", "Content-Type"=>"application/x-www-form-urlencoded", "Host"=>"httpbin.org", "User-Agent"=>"rest-client/2.0.2 (darwin18.0.0 x86_64) ruby/2.5.3p105"}, "json"=>nil, "origin"=>"0.0.0.0", "url"=>"https://httpbin.org/post?foo=bar&baz=qux"}
Rails 从 JIT 上获益现在所做的还远不够,一方面 Rails 的一个瓶颈是 I/O 模型,这一点不能靠 JIT 来解决。但有一点是可以的,就是 Rails 过深的中间件产生了过深的栈让内存调用非常吃紧。如果我们的 JIT 可以更进一步,在编译过程中对内存进行适当的优化,就可以有效提供其性能。但这一点暂时不是 2.6 的目标,但会是未来 Ruby JIT 的工作重点。
然而今天要发布 2.6.0-rc2 了。。。
反过来的话,你甚至也可以在 Ruby 上跑 Jupyter 比如 https://github.com/SciRuby/iruby 另外我常用的把生产数据拉来给机器学习的方法就是在 Ruby 里做数据预处理,然后使用 https://github.com/mrkn/pycall.rb 在 Ruby 里调用 Python 再去调用 Keras 做神经网络。