- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 C++ 中使用 isdigit()
函数,但我发现它很慢,所以我实现了我自己的 is_digit()
,请看下面我的代码:
#include<iostream>
#include<cctype>
#include<ctime>
using namespace std;
static inline bool is_digit(char c)
{
return c>='0'&&c<='9';
}
int main()
{
char c='8';
time_t t1=clock(),t2,t3;
for(int i=0;i<1e9;i++)
is_digit(c);
t2=clock();
for(int i=0;i<1e9;i++)
isdigit(c);
t3=clock();
cout<<"is_digit:"<<(t2-t1)/CLOCKS_PER_SEC<<"\nisdigit:"<<(t3-t2)/CLOCKS_PER_SEC<<endl;
return 0;
}
运行后,is_digit()
只用了1秒(1161ms),而isdigit()
却用了4秒(3674ms),我知道isdigit
是位运算实现的,isdigit()
不应该比is_digit()
快吗?
更新1
我使用 MS VS2010 和默认选项,发布版本,如何使 isdigit()
比 VS 中的 is_digit()
更快?
更新2
谢谢大家。在 VS 中处于 Release模式时,项目将针对速度默认值(-O2)进行优化。
全部处于 Release模式。
VS2010:is_digit:1182(ms)isdigit:3724(ms)
VS2013:is_digit:0(ms)isdigit:3806(ms)
带有 g++(4.7.1) 和 -O3 的代码块:is_digit:1275(ms)isdigit:1331(ms)
结论是:
is_digit()
比 VS 中的 isdigit()
快,但比 g++ 中的 isdigit()
慢。
而且 g++ 中的 isdigit()
比 VS 中的 isdigit()
更快。
所以“VS 很烂”的性能?
最佳答案
在 clang/llvm [我选择的编译器] 中,isdigit
和 is_digit
将变成完全相同的代码,因为它针对特定的库调用进行了优化,将其转换为 ((unsigned)(c-48) < 10u)
.
return c>='0' && c <='9';
也变成了c-48 > 10
通过优化(作为编译器执行的通用 if x >= N && x <= M
-> x-N > (M-N)
转换)。
因此,理论上,这两个循环应该变成相同的代码(至少使用对 isdigit
进行此类优化的编译器 - 我不能说 MSVC 是否这样做,因为源代码不提供给一般公众)。我知道gcc有类似的优化库调用的代码,但是目前我的机器上没有gcc源码,懒得去查[以我的经验,会难一点无论如何阅读都比 llvm 代码好。
llvm 中的代码:
Value *LibCallSimplifier::optimizeIsDigit(CallInst *CI, IRBuilder<> &B) {
Function *Callee = CI->getCalledFunction();
FunctionType *FT = Callee->getFunctionType();
// We require integer(i32)
if (FT->getNumParams() != 1 || !FT->getReturnType()->isIntegerTy() ||
!FT->getParamType(0)->isIntegerTy(32))
return nullptr;
// isdigit(c) -> (c-'0') <u 10
Value *Op = CI->getArgOperand(0);
Op = B.CreateSub(Op, B.getInt32('0'), "isdigittmp");
Op = B.CreateICmpULT(Op, B.getInt32(10), "isdigit");
return B.CreateZExt(Op, CI->getType());
}
对于那些不熟悉 LLVM 代码的人:它首先检查函数调用是否具有正确的参数数量和参数类型。如果失败,它返回 NULL 以指示“我无法优化它”。否则,它会构建操作链来执行 if (c - '0' > 10)
。使用无符号比较来处理“负”值[在无符号中是巨大的值]。
这样做会出错:
bool isdigit(int x)
{
return image_contains_finger(imagefiles[x]);
}
[但是用你自己的版本替换库函数通常会产生有趣的效果!]
关于c++ - isdigit() 在 C++ 中不应该更快吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28425292/
我正在尝试在Elasticsearch中返回的值中考虑地理位置的接近性。我希望近距离比某些字段(例如legal_name)重要,但比其他字段重要。 从文档看来,当前的方法是使用distance_fea
我是Elasticsearch的初学者,今天在进行“多与或”查询时遇到问题。 我有一个SQL查询,需要在Elastic中进行转换: WHERE host_id = 999 AND psh_pid =
智能指针应该/可以在函数中通过引用传递吗? 即: void foo(const std::weak_ptr& x) 最佳答案 当然你可以通过const&传递一个智能指针。 这样做也是有原因的: 如果接
我想执行与以下MYSQL查询等效的查询 SELECT http_user, http_req_method, dst dst_port count(*) as total FROM my_table
我用这两个查询进行测试 用must查询 { "size": 200, "from": 0, "query": { "bool": { "must": [ { "mat
我仍在研究 Pro Android 2 的简短服务示例(第 304 页)同样,服务示例由两个类组成:如下所示的 BackgroundService.java 和如下所示的 MainActivity.j
给定标记 like this : header really_wide_table..........................................
根据 shouldJS 上的文档网站我应该能够做到这一点: ''.should.be.empty(); ChaiJS网站没有使用 should 语法的示例,但它列出了 expect 并且上面的示例似乎
我在 Stack Overflow 上读到一些 C 函数是“过时的”或“应该避免”。你能给我一些这种功能的例子以及原因吗? 这些功能有哪些替代方案? 我们可以安全地使用它们 - 有什么好的做法吗? 最
在 C++11 中,可变参数模板允许使用任意数量的参数和省略号运算符 ... 调用函数。允许该可变参数函数对每个参数做一些事情,即使每个参数的事情不是一样的: template void dummy(
我在我从事的项目之一上将Shoulda与Test::Unit结合使用。我遇到的问题是我最近更改了此设置: class MyModel :update end 以前,我的(通过)测试看起来像这样: c
我该如何做 or使用 chai.should 进行测试? 例如就像是 total.should.equal(4).or.equal(5) 或者 total.should.equal.any(4,5)
如果您要将存储库 B 中的更改 merge 到存储库 A 中,是否应该 merge .hgtags 中的更改? 存储库 B 可能具有 A 中没有的标签 1.01、1.02、1.03。为什么要将这些 m
我正在尝试执行X AND(y OR z)的查询 我需要获得该代理为上市代理或卖方的所有已售属性(property)。 我只用 bool(boolean) 值就可以得到9324个结果。当我添加 bool
我要离开 this教程,尝试使用 Mocha、Supertest 和 Should.js 进行测试。 我有以下基本测试来通过 PUT 创建用户接受 header 中数据的端点。 describe('U
我正在尝试为 Web 应用程序编写一些 UI 测试,但有一些复杂的问题希望您能帮助我解决。 首先,该应用程序有两种模式。其中一种模式是“训练”,另一种是“现场”。在实时模式下,数据直接从我们的数据库中
我有一个规范: require 'spec_helper' # hmm... I need to include it here because if I include it inside desc
我正在尝试用这个测试我在 Rails 中的更新操作: context "on PUT to :update" do setup do @countdown = Factory(:count
我还没有找到合适的答案: onclick="..." 中是否应该转义 &(& 符号)? (或者就此而言,在每个 HTML 属性中?) 我已经尝试在 jsFiddle 和 W3C 的验证器上运行转义和非
import java.applet.*; import java.awt.*; import java.awt.event.*; public class Main extends Applet i
我是一名优秀的程序员,十分优秀!