小编Eug*_*Loy的帖子

处理Linux上的库依赖关系

我在我的项目中使用libcurl,它依赖于openssl和其他一堆.so在运行时。
这种依赖有点麻烦,因为不同的发行版/版本可能包含不同的opensl版本。

例如,如果我在Ubuntu 9.10上编译应用程序,则遇到在Ubuntu 11.10上运行的问题。

我看到了两种解决方案,但是对于我的情况,它们都不足够:

  1. 打包我的应用程序,然后让程序包管理器解决此类问题

  2. 静态链接所有部门

我的应用程序确实很小,并且打包/维护它会过大。另外,要求之一是它应可下载并运行。因此,(1)对我而言不是一个选择。

静态链接(2)并不是一个不错的解决方案,但是似乎libcurs并没有libopenssl,libcrypto和其他可传递依赖项的静态二进制分发。

从理论上讲,我可以尝试在libcurl后面手动构建所有的libs动物园,但这似乎会使维护变得更加复杂。

所以,这是一个问题-我错过了什么吗?有没有一种更轻松的方式来减轻我在Linux世界中的痛苦(具体来说是Ubuntu)?任何建议都欢迎。

c++ linux dependencies openssl libcurl

5
推荐指数
1
解决办法
3403
查看次数

Rackspace云文件(使用jclouds) - 如何获取容器位置

我使用jclouds作为Rackspace Cloud Files的api.

Api允许我使用BlobStore.createContainerInLocation在不同位置创建容器

现在,拥有已经存在的容器,我该如何获取它的位置?

java rackspace rackspace-cloud jclouds rackspace-cloudfiles

5
推荐指数
1
解决办法
567
查看次数

Scala集合:一次性转换集合的内容和类型

我正在寻找一种有效转换集合的内容类型的方法.

例如,应用于mapa Set并获得结果List.

请注意,我想在将转换应用于源集合时构建结果集合(即,不创建中间集合,然后将其转换为所需类型).

到目前为止,我已经提出了这个问题(为了在增加每个元素的同时Set进行转换):Listset

val set = Set(1, 2, 3)

val cbf = new CanBuildFrom[Set[Int], Int, List[Int]] {
    def apply(from: Set[Int]): Builder[Int, List[Int]] = List.newBuilder[Int]
    def apply(): Builder[Int, List[Int]] = List.newBuilder[Int]
}

val list: List[Int] = set.map(_ + 1)(cbf)
Run Code Online (Sandbox Code Playgroud)

...但我觉得应该有更简短和优雅的方法来做到这一点(CanBuildFrom每次我需要时都不需要手动执行).

任何想法如何做到这一点?

scala scala-collections

5
推荐指数
1
解决办法
71
查看次数

我可以将泛型类型参数限制为2个不相关的类之一吗?

我希望能够做这样的事情(实际上不会起作用):

class A[T <: B | C]
Run Code Online (Sandbox Code Playgroud)

......并希望这是有效的:

new A[B]
new A[C]
Run Code Online (Sandbox Code Playgroud)

...这会产生编译器错误:

new A[D]
Run Code Online (Sandbox Code Playgroud)

这样的事情可能吗?

generics scala

5
推荐指数
1
解决办法
402
查看次数

阿卡:测试监控\死亡手表

在我的场景中,我有2个演员:

  1. watchee(我用TestProbe)
  2. watcher(Watcher包裹在我的测试中TestActorRef暴露一些内部stateI轨道)

守望者应该在watchee死亡时采取一些行动.

这是我到目前为止编写的完整测试用例:

class TempTest(_system: ActorSystem) extends TestKit(_system) with ImplicitSender with FunSuiteLike with Matchers with BeforeAndAfterAll {

  def this() = this(ActorSystem("TempTest"))

  override def afterAll {
    TestKit.shutdownActorSystem(system)
  }

  class WatcherActor(watchee: ActorRef) extends Actor {

    var state = "initial"
    context.watch(watchee)

    override def receive: Receive = {
      case "start" =>
        state = "start"
      case _: Terminated =>
        state = "terminated"
    }

  }

  test("example") {
    val watchee = TestProbe()
    val …
Run Code Online (Sandbox Code Playgroud)

testing scala akka akka-testkit akka-monitoring

5
推荐指数
2
解决办法
2555
查看次数

类型和泛型:`[X <:Int]`和`{type X <:Int}`之间的区别

据我所知,这两个函数是等价的:

def x(xx: X forSome { type X <: Int }): Unit = ()

def y[Y <: Int](yy: Y): Unit = ()
Run Code Online (Sandbox Code Playgroud)

根据我的观察,现在人们大多使用第二种形式(使用[]),同时我有时会看到使用第一种形式的文章(大多是旧的,讨论存在类型)(forSome).

有2个符号的原因是什么?有没有一个专业人士或缺点或你可以\使用一个或另一个不能做的事情?

generics types scala existential-type

5
推荐指数
1
解决办法
83
查看次数

OpenSSL二进制分发:版本末尾的char的含义

我使用依赖于OpenSSL的libcurl,因此我也需要链接它.

目前的Windows二进制分发在这里,但我不明白什么是字符在该版本的结束代表(命名为喜欢的包:Win32的OpenSSL的v1.0.1b的Win32 OpenSSL的v1.0.0i,...).

我可能会错过一些东西,但很快潜伏在网站/页面上没有给出任何解释.

他们之间有什么区别?

openssl

4
推荐指数
1
解决办法
964
查看次数

显示来自多个用户的推文(类似于嵌入式时间线),没有推特侧用户列表

我是Twitter新手,需要一些提示.

我需要在某个网页上显示来自多个用户的推文Feed.

我偶然发现的第一件事是嵌入式时间线.它允许显示来自用户列表的推文,但问题是这些列表应该在Twitter端维护(即我不能仅在我这边指定@qwe和@asd并获得时间线而不将这些用户添加到Twitter端的列表中).

问题是应该包含在时间轴中的用户列表是动态的,通过Twitter API管理这些列表可能会很痛苦.更不用说我的网站可能会生成大量的这些列表,我觉得我迟早会违反一些api配额.

所以,我的问题是 - 我是否坚持使用嵌入式时间线,在Twitter端引用一些用户列表并通过Twitter REST api管理这些列表,或者有一种更简单的方法来做我想要的事情?

twitter

4
推荐指数
1
解决办法
8151
查看次数

需要帮助建立有效的穷举搜索算法

有10个按钮.如果按正确顺序按下这些按钮可以解锁(按顺序按5次).按下每个按钮会触发解锁检查.

例如:"密码"是123456,我按下按钮0 1 2 3 4 5 6我从第6次按下按钮解锁.

我需要设计算法,以最有效的方式尝试所有可能的组合(即应按下最少量的按钮).

我可以将按钮编号按顺序解释为数字和按下按钮的数字作为数字位置,然后尝试所有99999组合以尝试解锁,但我觉得有更有效的算法可以做到这一点.

有什么我可以做的来优化这个搜索?

algorithm math search combinatorics

3
推荐指数
1
解决办法
908
查看次数

儿童演员是否知道他正在恢复?

想象一下直截了当的监督层级.孩子死了.父亲决定要Restart孩子.当Restart编辑时,postRestart和朋友们一起打电话,但如果父亲决定重新开始孩子怎么办?儿童演员是否知道他正在恢复?顺便说一下.父亲是否可以访问导致孩子出现异常的信息?

fault-tolerance actor akka akka-supervision

3
推荐指数
1
解决办法
977
查看次数