草庐IT

cpu-time

全部标签

c++ - boost Date_Time 日期解析不起作用

我正在尝试使用boost1.55Date_Time库编写代码来解析日期时间字符串。但它总是产生非日期时间日期。boost::gregorian::dated(2005,6,25);boost::gregorian::dated2;boost::gregorian::date_facet*facet(newboost::gregorian::date_facet("%Y%m%d"));stringstreamss;ss.imbue(std::locale(std::cout.getloc(),facet));ss>d2;//not-a-date-timecout我尝试了不同的格式说明符,

C++ 蛇克隆 : timer function ignores given stop time and stops at it's own fixed time

我正在尝试使用C++和OpenGL/GLUT制作一个Snake克隆。然而,我一直在编程允许输入Action之间的短时间间隔时遇到问题。我已经尝试了一些计时方法,最后我为它创建了一个类(如下所示)。这似乎是对输入延迟进行编程的最佳方式(而不是glutTimerFunc()或sleep()),因为计时器独立于游戏循环运行,而不是暂停整个程序。这很重要,因为我希望播放器能够随时暂停。不幸的是,我现在也遇到了这种方法的问题。我的计时器类似乎忽略了我给它的双倍时间限制(简单表示为双倍“限制”)。为了测试该类,我设置了一个简单的循环控制台程序,该程序在计时器达到时间限制时显示来自用户的定向输入。它

把个人电脑上的 CPU 拔下来插到服务器上行不行?

大家好,我是飞哥!首先祝大家新年快乐,新的一年的技术分享又开始了!大家都对个人电脑的CPU有不少的了解,但对服务器CPU没有亲眼见过。所以总会有人会产生疑问,把我自己的PC办公电脑上的CPU拔下来插到服务器上行不行。答案当然是否定的。服务器CPU和个人电脑中的CPU存在很多差别。今天我用一篇文章给大家总结下,服务器CPU和个人台式机电脑CPU之间都存在哪些的差别。说明:Intel官方的文档中用server来指代服务器CPU,会用client来指代个人台式机电脑中使用的CPU。1.尺寸不一样从外观上来看,serverCPU要比clientCPU要大不少。图片再看官方数据。拿Skylake来举例,

实战!使用 阿里 Arthas 工具分析 CPU 飙高

Arthas是阿里开源的Java诊断工具,相比JDK内置的诊断工具,要更人性化,并且功能强大,可以实现许多问题的一键定位,而且可以一键反编译类查看源码,甚至是直接进行生产代码热修复,实现在一个工具内快速定位和修复问题的一站式服务。今天,我就带你使用Arthas定位一个CPU使用高的问题,系统学习下这个工具的使用。首先,下载并启动Arthas:curl-Ohttps://alibaba.github.io/arthas/arthas-boot.jarjava-jararthas-boot.jar启动后,直接找到我们要排查的JVM进程,然后可以看到Arthas附加进程成功:[INFO]arthas

c++ - 使用自定义时区将 boost::posix_time::ptime 转换为字符串

我有一个boost::posix_time::ptime实例并希望使用给定的boost::local_time::time_zone_ptr将其转换(“格式化”)为字符串实例。下面是一个显示我目前拥有的测试程序。它转换ptime到local_date_time据我了解,除了时间信息外,它还表示时区。在2011-08-1812:00:00UTC运行这个程序时,我期望输出2011-08-1814.00.00UTC+02:00.相反,它打印2011-08-1812:00:00UTC+00:00.即相对于打印的时区,打印的时间是正确的,但它不在我用来创建boost::local_time::l

c++ - boost::mutex 和 boost::timed_mutex 的区别

根据Boost文档,boost::mutex和boost::timed_mutex应该是不同的。第一个实现了LockableConcept,第二个实现了TimedLockableConcept。但是如果你看一下源代码,你会发现它们基本上是一样的。唯一的区别是锁类型定义。您可以在boost::mutex上调用timed_lock或使用带超时的boost::unique_lock。typedef::boost::detail::basic_timed_mutexunderlying_mutex;classmutex:public::boost::detail::underlying_mut

c++ - 不同 CPU 上 sin 的不同值

我正在编写一个用于计算一些几何变换的应用程序,在测试该程序时,我发现了一些奇怪的东西:我在两台不同的机器上启动了测试,Z400工作站配备Intel®Xeon®处理器W3550和Z800工作站使用英特尔®至强®处理器X5560,一次操作得到了不同的结果:doublex=24.169408798217777*sin(0.59420877837561048)/sin(0.97658754841928608)使用Z400,我得到了x=16.330508228047432虽然Z800抛出这个值x=16.330508228047435最后一位的值不同,我用那个值做了很多计算,所以很不方便。我尝试使

c++ - 是否可以在 "reserved"cpu 内核上运行代码?

简化背景:我的应用程序运行很多任务。其中大部分是CPU密集型的。一个任务(实际上是一个循环运行的单线程,监听来自网络的数据包)是一个非常“实时”的任务。更有趣的是,该线程是使用pinvoke调用的native代码。问题:当显示大量流量时,任务非常努力,所有核心都已满负荷运转。发生这种情况时,“实时”线程(在100%cpu内核上运行)开始丢弃数据包,因为它没有获得足够的cpu时间。问题:有可能以某种方式为“实时”线程“保留”一个核心,并将所有其他线程(任务)限制到其他核心吗?当然,还有其他进程在运行,也消耗CPU时间,但我们假设它们消耗的资源很少且持续存在。这是一个真正的问题,可以通过“

c++ - get_time 未按预期运行

我在尝试使用put_time和get_time函数时遇到了一些问题。我拿了这段代码:#include#include#include#includeintmain(){std::tmt={};std::istringstreamss("2011-Februar-1823:12:34");ss.imbue(std::locale("de_DE.utf-8"));ss>>std::get_time(&t,"%Y-%b-%d%H:%M:%S");if(ss.fail()){std::cout来自here.但是,当同时使用gcc版本8.8.1和clang版本6.0.0进行编译时,我得到解析失败

c++ - boost::filesystem::last_write_time 在哪里?

这是我收到的链接器错误。我的所有其他boost::filesystem事情都在解决。我不明白为什么这个不。以为是boost1.40的问题,升级到1.44,问题依旧。我正在使用#defineBOOST_FILESYSTEM_VERSION3但我没有看到在这种情况下未提供last_write_time的提及。似乎缺少底层实现,即使存在api部分。1>TestPruner.obj:errorLNK2019:unresolvedexternalsymbol"void__cdeclboost::filesystem3::detail::last_write_time(classboost::fi