小编Opt*_*Opt的帖子

纯函数式编程的效率

有没有人知道什么是最简单的渐近减速,当编程纯粹功能而不是命令性(即允许副作用)时可能发生?

来自itowlson评论的澄清:有没有哪个问题最着名的非破坏性算法渐渐比最着名的破坏性算法更糟糕,如果是这样的话多少呢?

algorithm performance functional-programming

395
推荐指数
3
解决办法
6万
查看次数

在C++ 0x中传递/移动构造函数的参数

如果我有一个带有n个参数的构造函数,那么任何参数都可以是rvalue和lvalue.是否可以通过为rvalues移动语义来支持这一点,而无需为每个可能的rvalue/lvalue组合编写2 ^ n个构造函数?

c++ rvalue-reference move-constructor c++11

25
推荐指数
1
解决办法
3989
查看次数

C++中size_t的性能

我将这里的代码翻译成C++,如下所示

#include <iostream>

using namespace std;

int t = 20;

bool is_evenly_divisible(const int a, const int b) {
    for (int i=2; i<=b; ++i) { // Line 1
        if (a%i != 0)
            return false;
    }
    return true;
}

void run() {
    int i = 10;
    while (!is_evenly_divisible(i, t)) {
        i += 2;
    }
    cout << i << endl;
}

int main(int argc, char** argv) {
    run();
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

在Mac OSX 10.8.4上使用编译器g ++ 4.8.1上的-O3标志,我得到0.568s用户时间.

现在,如果我将第1行中的计数器i在函数is_evenly_divisible中更改为size_t,则时间突然跳至1.588s.即使我将所有变量更改为size_t,这仍然存在,时间增加到1.646s

发生了什么?size_t不应该提高性能而不是降低性能,因为它比int更具体吗?

c++ int performance size-t c++11

10
推荐指数
1
解决办法
2855
查看次数

posix_memalign for std :: vector

有没有办法posix_memalign std :: vector而不先创建向量的本地实例?我遇到的问题是我需要告诉posix_memalign分配多少空间我不知道怎么说

sizeof(std::vector<type>(n)) 
Run Code Online (Sandbox Code Playgroud)

没有实际创建新的矢量.

谢谢

c++ stl dynamic-memory-allocation

7
推荐指数
1
解决办法
2048
查看次数

动态分配的数组或std :: vector

我正在尝试优化我的C++代码.我使用动态分配的C++数组和使用std :: vector搜索互联网,并且通常看到有利于std :: vector的建议,并且两者之间的性能差异可以忽略不计.例如,在C++中使用数组或std :: vector,性能差距是多少?.

但是,我编写了一些代码来测试迭代数组/向量并为元素赋值的性能,我通常发现使用动态分配的数组比使用向量快近3倍(我事先指定了向量的大小) ).我用过g ++ - 4.3.2.

但是我觉得我的考试可能忽略了我不知道的问题,所以我很感激你对这个问题的任何建议.

谢谢

使用的代码 -

#include <time.h>
#include <iostream>
#include <vector>

using namespace std;

int main() {
  clock_t start,end;
  std::vector<int> vec(9999999);
  std::vector<int>::iterator vecIt = vec.begin();
  std::vector<int>::iterator vecEnd = vec.end();

  start = clock();
  for (int i = 0; vecIt != vecEnd; i++) {
    *(vecIt++) = i;
  }
  end = clock();
  cout<<"vector: "<<(double)(end-start)/CLOCKS_PER_SEC<<endl;

  int* arr = new int[9999999];
  start = clock();
  for (int i = 0; i < 9999999; …
Run Code Online (Sandbox Code Playgroud)

c++ optimization performance stl

6
推荐指数
3
解决办法
5199
查看次数

将一系列击键映射到命令行命令

有没有办法将一系列击键映射到:vim中的命令行命令(在Ex模式下输入的命令)?

vim

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

移动.hg文件夹

嘿,我正在使用Mercurial.我刚刚发现我的主目录中有一个.hg文件夹.我认为它跟踪我在我的主目录中所有的mercurial存储库.这是真的?

另外,我需要将.hg文件夹移动到另一个目录.任何人都可以指导我如何做到这一点?

谢谢

mercurial

2
推荐指数
1
解决办法
3119
查看次数

HZ变量未定义

我正在尝试编译某人的代码而且该人正在使用变量HZ(我认为它代表Hertz用于cpu的hertz)但编译器抱怨该变量未定义.我的猜测是该人没有包含正确的头文件.

那么有谁知道哪个头文件,HZ定义在哪?

谢谢

编辑:编译适用于Debian g ++版本4.3.2
我正在使用的设置 - OSX Leopard 10.5.8,g ++版本4.0.1是失败的地方.

c++ header-files

1
推荐指数
2
解决办法
2468
查看次数

Mercurial - 忽略大文件

我知道有一种方法可以使用hgignore来忽略特定文件.

有没有办法让它忽略超过一定大小的所有文件?

谢谢

mercurial

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