我对这个问题的回答是“否”。但我的同事不同意。
我们正在重建我们的产品,并在近期内做出许多关键决策。
在做我自己的一些工作时,我注意到我们有一些内部 C++ 类来抽象一些 POSIX API(线程、互斥量、信号量和 rw 锁)和其他实用程序类。请注意,这些类是基本类,尚未从 Linux 移植(可移植性是重建的一个因素。)我们还使用 POCO C++ 库。
我将此事提请我的同事注意,并建议我们放弃内部类(class),转而使用 POCO 类(class)。我想充分利用我们已经在使用的库。他们建议我们应该使用 POCO 实现我们的内部类,并在必要时进一步抽象额外的 POCO 类,以免依赖于任何特定的 C++ 库(引用 future 的未知数——如果我们想使用不同的库/框架怎么办? QT或者boost,万一我们选的不好或者开发不活跃怎么办等等)
他们也不想重构遗留代码,通过用我们自己的类抽象部分 POCO,我们可以实现额外的功能(经典 OOP)。我可以理解这两个论点。但是,我认为如果我们正在重新编码,我们应该做大,或者回家。现在是重构的时候了,它真的不应该那么糟糕,特别是考虑到我们的类与 POCO 中的类(线程等)之间的相似性。我不知道关于第二点该说些什么 - 我们应该只使用需要功能的扩展类?
我的同事也不想到处乱扔 POCO 命名空间。我认为我们应该选择一个库/框架/工具包,并坚持使用它。充分利用其功能。这不是典型的做法吗?我见过的唯一一个抽象整个框架的项目是 Freeswitch(它提供自己的 APR 接口(interface)。)
一个建议是,我们向彼此和潜在客户公开的 API 应该没有 POCO,但它会出现在实现中(这是有道理的。)
我们当中没有人真正有过此类设计决策的经验,这在当前的产品中有所体现。我从小就从事这项工作,有些直觉让我来到这里,但也没有实际经验。我真的很想避免对已经解决的问题提出糟糕的解决方案。
我想我的问题可以归结为:在构建产品时,我们是否应该 a) 选择一个主要框架作为我们大部分代码的基础,并且 b) 期望该框架与产品紧密耦合?这不是框架的重点吗? (框架还是库更适合POCO?)
最佳答案
首先,您公开的 API 绝对应该不含 POCO、boost、qt 或任何其他不属于标准 C++ 库的类型。这是因为基础库有自己的发布周期,与您的库的发布周期不同。如果您的库的用户也使用 boost,但使用的是不同的、不兼容的版本,他们将需要花时间来解决不兼容问题。这条规则的唯一异常(exception)是当你设计一个库作为更广泛的框架的一部分发布时——比如,一个 POCO 工具包的补充。在这种情况下,您的库的发布与整个工具包的发布相关联。
但是,在内部,您应该避免使用自己的包装器,除非您要抽象出的库是真正的“商品库”1。这样做的原因是,当你在你的类后面隐藏一个外部库时,大多数时候你会模仿你所隐藏的库的抽象级别。使用包装器的代码将编程到外部库规定的抽象级别。当您将包装器背后的实现换成不同的框架时,您很可能会 (1) 调整新框架以适应旧框架的抽象级别,或者 (2) 需要更改你使用你的包装。这两种情况都非常可疑:如果您执行 (1),也许您一开始就不应该切换,如果您执行 (2),那么您的包装器将被证明是无用的。
关于c++ - 从实现中抽象出库依赖是一种常见的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12372792/
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
如何将send与+=一起使用?a=20;a.send"+=",10undefinedmethod`+='for20:Fixnuma=20;a+=10=>30 最佳答案 恐怕你不能。+=不是方法,而是语法糖。参见http://www.ruby-doc.org/docs/ProgrammingRuby/html/tut_expressions.html它说Incommonwithmanyotherlanguages,Rubyhasasyntacticshortcut:a=a+2maybewrittenasa+=2.你能做的最好的事情是:
文章目录git常用命令(简介,详细参数往下看)Git提交代码步骤gitpullgitstatusgitaddgitcommitgitpushgit代码冲突合并问题方法一:放弃本地代码方法二:合并代码常用命令以及详细参数gitadd将文件添加到仓库:gitdiff比较文件异同gitlog查看历史记录gitreset代码回滚版本库相关操作远程仓库相关操作分支相关操作创建分支查看分支:gitbranch合并分支:gitmerge删除分支:gitbranch-ddev查看分支合并图:gitlog–graph–pretty=oneline–abbrev-commit撤消某次提交git用户名密码相关配置g
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
我最喜欢的Google文档功能之一是它会在我工作时不断自动保存我的文档版本。这意味着即使我在进行关键更改之前忘记在某个点进行保存,也很有可能会自动创建一个保存点。至少,我可以将文档恢复到错误更改之前的状态,并从该点继续工作。对于在MacOS(或UNIX)上运行的Ruby编码器,是否有具有等效功能的工具?例如,一个工具会每隔几分钟自动将Gitcheckin我的本地存储库以获取我正在处理的文件。也许我有点偏执,但这点小保险可以让我在日常工作中安心。 最佳答案 虚拟机有些人可能讨厌我对此的回应,但我在编码时经常使用VIM,它具有自动保存功
我希望用户从一个模型的三个选项中选择一个。即我有一个模型视频,可以被评为正面/负面/未知目前我有三列bool值(pos/neg/unknown)。这是处理这种情况的最佳方式吗?为此,表单应该是什么样的?目前我有类似的东西但显然它允许多项选择,而我试图将它限制为只有一个..怎么办? 最佳答案 如果要使用字符串列,让我们说rating。然后在你的表单中:#...#...它只允许一个选择编辑完全相同但使用radio_button_tag: 关于ruby-on-rails-Rails单选按钮-模
a=[3,4,7,8,3]b=[5,3,6,8,3]假设数组长度相同,是否有办法使用each或其他一些惯用方法从两个数组的每个元素中获取结果?不使用计数器?例如获取每个元素的乘积:[15,12,42,64,9](0..a.count-1).eachdo|i|太丑了...ruby1.9.3 最佳答案 使用Array.zip怎么样?:>>a=[3,4,7,8,3]=>[3,4,7,8,3]>>b=[5,3,6,8,3]=>[5,3,6,8,3]>>c=[]=>[]>>a.zip(b)do|i,j|c[[3,5],[4,3],[7,6],
我正在构建一个应用程序,想知道是否将未使用的对象设置为nil是生产级编码中的常见做法。我知道这只是垃圾收集器的提示,并不总是处理对象。 最佳答案 根据这个thread如果您使用完一个成员对象,将其设置为nil将引发被引用对象被垃圾回收。如果它是局部变量,方法exit将做同样的事情。也就是说,如果您要求将成员显式设置为nil,我会质疑您的设计。 关于ruby-将对象设置为nil是否很常见?,我们在StackOverflow上找到一个类似的问题: https://