- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我对 scoped_lock 的工作原理感到非常兴奋,并且想知道是否可以完成类似的实现来为特定的执行代码计时
如果说我实现了一个简单的类 scoped_timer,它在构建时启动一个计时器并在删除时停止并报告耗时,那么这个示例代码是否会正确计时
func()
{
//some code
{
scoped_timer a;
//some code that does not include a
}
//some code
}
在实践中,我保证 scoped_time a
在开始时构造,并在超出范围时准确销毁。编译器能否决定以不恰好在作用域末尾破坏代码或在开头构造代码的方式重新排序代码,因为不依赖于 object a
? C++ 标准是否有保证?
谢谢
丹尼尔
最佳答案
代码保证按照您的意愿运行。
这个保证在 C++ 中很重要,因为 C++ 不是 functional programming language ,由于 C++ 中的几乎所有函数都可能有副作用(无论是来自当前线程的执行流,还是来自其他线程甚至其他进程,无论数据是否声明为 volatile
)。因此,语言规范对完整表达式的顺序做出了保证。
为了将 C++11 标准拼凑起来,有许多子句必须一起考虑。
最重要的条款是§1.9:
§1.9 Program execution [intro.execution]
1 The semantic descriptions in this International Standard define a parameterized nondeterministic abstract machine. This International Standard places no requirement on the structure of conforming implementations. In particular, they need not copy or emulate the structure of the abstract machine. Rather, conforming implementations are required to emulate (only) the observable behavior of the abstract machine as explained below. * (<-- the footnote is in the standard itself)
* This provision is sometimes called the “as-if” rule, because an implementation is free to disregard any requirement of this International Standard as long as the result is as if the requirement had been obeyed, as far as can be determined from the observable behavior of the program. For instance, an actual implementation need not evaluate part of an expression if it can deduce that its value is not used and that no side effects affecting the observable behavior of the program are produced.
(文字的粗体是我的。)
该条款提出了与该问题相关的两个重要要求。
如果一个表达式可能有副作用,它会被评估。在你的例子中,表达式 scoped_timer a;
可能有副作用,所以它会被评估。
“...需要符合要求的实现来模拟(仅)抽象机的可观察行为,如下所述。”,其中“以下”包括第 13 条和第 14 条相同部分:
§1.9.13 Sequenced before is an asymmetric, transitive, pair-wise relation between evaluations executed by a single thread (1.10), which induces a partial order among those evaluations. Given any two evaluations A and B, if A is sequenced before B, then the execution of A shall precede the execution of B. If A is not sequenced before B and B is not sequenced before A, then A and B are unsequenced. [ Note: The execution of unsequenced evaluations can overlap. —end note ] Evaluations A and B are indeterminately sequenced when either A is sequenced before B or B is sequenced before A, but it is unspecified which. [ Note: Indeterminately sequenced evaluations cannot overlap, but either could be executed first. —end note ]
§1.9.14 Every value computation and side effect associated with a full-expression is sequenced before every value computation and side effect associated with the next full-expression to be evaluated. * (<-- the footnote here is not relevant)
因此,您的表达式 scoped_timer a;
(这是一个完整的表达式)可能会产生副作用,并且会被求值;因此 a
的值的计算将在 block 中的以下任何语句之前排序。
关于a
对象的销毁,比较简单。
§3.7.3.3 If a variable with automatic storage duration has initialization or a destructor with side effects, it shall not be destroyed before the end of its block, nor shall it be eliminated as an optimization even if it appears to be unused, except that a class object or its copy/move may be eliminated as specified in 12.8.
这清楚地表明在 block 退出之前不会调用析构函数。
ADDENDUM 并确认所有 block 级变量都在 block 作用域末尾销毁(并调用它们的析构函数),这里是在 C++ 中11 标准:
§3.7.3.1 Block-scope variables explicitly declared register or not explicitly declared static or extern have automatic storage duration. The storage for these entities lasts until the block in which they are created exits.
§3.7.3.2 [ Note: These variables are initialized and destroyed as described in 6.7. —end note ]
...和上述§6.7:
§6.7.2 Variables with automatic storage duration (3.7.3) are initialized each time their declaration-statement is executed. Variables with automatic storage duration declared in the block are destroyed on exit from the block (6.6).
该 block 定义为一对大括号 {}
之间的所有代码:
§6.3.1 So that several statements can be used where one is expected, the compound statement (also, and equivalently, called “block”) is provided.
compound-statement:
{ statement-seq }
statement-seq:
statement
statement-seq statementA compound statement defines a block scope (3.3).
注意:compount-statement
(等)部分需要一段时间才能习惯,但重要的一点是,左大括号 {
和右大括号花括号 }
实际上是指代码中的文字左花括号和右花括号。这是 C++11 标准中 block
范围被定义为花括号之间的语句序列的确切位置。
将各个部分放在一起:因为如上所述,标准说这些实体的存储持续到创建它们的 block 退出
并且声明了自动存储持续时间的变量 block 中的对象在退出 block 时被销毁
,您可以确信问题中的对象a
(以及任何 block 级对象)将持续到 block 结束,并且将被销毁并在 block 退出时调用其析构函数。
关于C++ 作用域变量重新排序和计时器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15777133/
这是我的本地域名 http://10.10.1.101/uxsurvey/profile/dashboard 在 Controller 中,我为用户列表设置了一个操作 redirect(control
要处理 Canonical URL,最佳做法是执行 301 重定向还是更好地为 www 和非 www 域使用相同的 IP 地址? 例如: 想要的规范 URL/域是 http://example.com
1 内网基础 内网/局域网(Local Area Network,LAN),是指在某一区域内有多台计算机互联而成的计算机组,组网范围通常在数千米以内。在局域网中,可以实现文件管理、应用软件共享、打印机
1 内网基础 内网/局域网(Local Area Network,LAN),是指在某一区域内有多台计算机互联而成的计算机组,组网范围通常在数千米以内。在局域网中,可以实现文件管理、应用软件共享、打印机
我想创建一个 weblogic 集群,其中有两个托管服务器,每个服务器在物理上独立的远程计算机上运行 根据weblogic文档 All Managed Servers in a cluster mus
我正在运行 grails 3.1.4,但在创建允许我将多个域对象绑定(bind)到其他几个域对象的模式时遇到了问题。作为我正在尝试做的一个例子: 我有三个类(class)。书籍、作者和阅读列表。 作者
我试图使用@count函数来根据它获取数据,但是在没有崩溃报告的情况下它以某种方式崩溃了。 这是代码 class PSMedia: Object { @objc dynamic var id
有谁知道是否有办法只输入字母字符而不输入数字?我想过这样的事情 CREATE DOMAIN countryDomain AS VARCHAR(100) CHECK( VALUE ??? );
我的代码: const checkoutUrl = 'https://example.com/checkout/*' window.onload = startup() function st
一些不是我编写的应用程序,也不是用 PHP 编写的,它为域 www.example.com 创建了一个 cookie。 我正在尝试替换该 cookie。所以在 PHP 中我做到了: setcookie
什么是 oauth 域?是否有任何免费的 oauth 服务?我可以将它用于 StackApps registration 吗? ?我在谷歌上搜索了很多,但找不到答案。 最佳答案 这是redirect_
自从 In October 2009, the Internet Corporation for Assigned Names and Numbers (ICANN) approved the cre
我使用 apache 作为我的应用程序 Web 服务器的代理,并希望即时更改与 sessionid cookie 关联的域名。 该cookie有一个与之关联的.company.com域,我想使用apa
我只想托管一个子域到cloudflare。我不想将主域名的域名服务器更改为他们的域名服务器。真的有可能吗? 最佳答案 是的,这是可能的,但是需要通过CloudFlare合作伙伴进行设置,或者您需要采用
When using socket in the UNIX domain, it is advisable to use path name for the directory directory m
想象两个共享一个域类的 Grails 应用程序。也许是 Book 域类。 一个应用程序被标识为数据的所有者,一个应用程序必须访问域数据。类似于亚马逊和亚马逊网络服务。 我想拥有的应用程序将使用普通的域
我有一个包含字段“URL”的表单。第一部分需要用户在文本框中填写。第二部分是预定义的,显示在文本框的右侧。 例如,用户在文本框中输入“test”。第二部分预定义为“.example.com”。因此,总
如果我要关闭并取消分配 azure 中的域 Controller ,从而生成新的 vm Generationid,我需要采取哪些步骤来恢复它? 最佳答案 what steps do I need to
我想尝试使用 Azure 作为托管提供商(我有一个域)。我读过那篇文章https://learn.microsoft.com/en-us/azure/app-service-web/web-sites
所以.... 我想知道是否有人可以在这方面协助我? 基本上,我已经创建了一个自托管的Docker容器,用作构建代理(Azure DevOps) 现在,我已经开始测试代理,并且由于我们的放置文件夹位于W
我是一名优秀的程序员,十分优秀!