jjzjj

placement

全部标签

javascript - 根据显示位置动态更改弹出窗口的位置

我想根据元素在屏幕上的位置动态更改弹出窗口的位置(左/右、上/下)。//get_popover_placement(dom_el)returns'left','right','top',or'bottom'functionset_popover(dom_el){varthe_placement=get_popover_placement(dom_el);$(dom_el).popover({offset:10,placement:the_placement}).popover('show');}//settheplacementoneveryhover$('a[data-rel=pop

c# - 获取另一个进程的窗口状态

如何获取正在运行的另一个进程的窗口状态(最大化、最小化)?我试过用这个:Process[]procs=Process.GetProcesses();foreach(Processprocinprocs){if(proc.ProcessName=="notepad"){MessageBox.Show(proc.StartInfo.WindowStyle.ToString());}}但是如果进程是Maximized或Minimized,它会返回Normal。如何解决这个问题? 最佳答案 您需要通过P/Invoke使用Win32来检查另一

c++ - 为什么不在 placement new 中隐式调用析构函数”?

如本网站所引用...http://www.parashift.com/c++-faq-lite/dtors.html#faq-11.10但是我没有找到原因,为什么我们要显式调用析构函数? 最佳答案 您可以将其视为对delete的调用,但由于您使用了placementnew,因此您不想使用delete,因为那样会尝试释放内存。如果你想让它自动调用,你可以使用RAII://Coulduseatemplatedversion,orfindanexistingimplsomewhere:voiddestroy_fred(Fred*f){f-

c++ - "placement new"具有通用成员变量的结构/类数组的正确方法是什么?

给定以下类:templateclassExample{structElement{std::size_tid;std::aligned_storage_tactual_data;};std::arraydata;public:templatevoidemplace_insert(Args&&...args){autosome_id=123;//forexample//placmentnewnew(&data[some_id])Element(some_id,T(std::forward(args)...));}};我将如何在emplace_insert函数中使用placementnew

c++ - Effective placement of lock_guard - 来自 Effective Modern C++ 的第 16 条

在第16项:“使const成员函数线程安全”中有一段代码如下:classWidget{public:intmagicValue()const{std::lock_guardguard(m);//lockmif(cacheValid)returncachedValue;else{autoval1=expensiveComputation1();autoval2=expensiveComputation2();cachedValue=val1+val2;cacheValid=true;returncachedValue;}}//unlockmprivate:mutablestd::mute

c++ - 你如何删除一个分配了 placement new 的对象

C++中的new运算符有很多面孔,但我对placementnew感兴趣。假设你在一个特定的内存位置分配内存intmemoryPool[poolSize*sizeof(int)];int*p=new(mem)int;//allocatesmemoryinsidethememoryPoolbufferdeletep;//segmentationfault在这种情况下,我如何正确地释放内存?如果我不使用内置类型int,而是使用某个名为myClass的类,会怎样?myClassmemoryPool[poolSize*sizeof(myClass)];myClass*p=new(mem)myCl

c++ - 安置新的和异常(exception)

“placementnew”运算符声明如下:void*operatornew(std::size_tsize,void*ptr)noexcept;但是虽然它不涉及任何实际分配,因此消除了错误的分配异常,但指针仍然可能指向错误的位置,在这种情况下,人们会期望得到一个范围或溢出/下溢错误,但是它被声明为noexcept的事实不会直接终止执行吗?这是否也意味着在C++11之前放置new将抛出并尝试处理std::unexpected而不是直接处理std::set_unexpected崩溃?“以防万一”,难道不应该有大量的placementnew吗? 最佳答案

c++ - 我如何在这里使用 placement new ?

我有一block内存区域,将用于多个队列。比如我分配了1024字节的内存,需要两个队列。第一个队列将占用前512个字节,第二个队列将占用接下来的512个字节。但是,我的队列由C++类表示。使用placementnew运算符,我如何构造每个队列对象。以下做法是否正确?Queue*q1,*q2;void*mem=malloc(1024);*q1=new(mem)Queue;*q2=new(mem+512)Queue; 最佳答案 我会做以下事情:Queue*mem=static_cast(malloc(2*sizeof(Queue));Q

c++ - 使用 placement new 在构造函数中调用构造函数

这几天很挣扎。问题是构造函数调用。我写了一段代码:#includeusingnamespacestd;classFoo{private:int_n;public:Foo(){Foo(5);}Foo(intn){_n=n;cout当我使用默认构造函数在外部构造一个Foo对象时:Foo*f=newFoo();我假设变量_n是5,然而,它不是。在Java中可以,但在C++中不行。此外,在VisualC++6sp6中,Foo(){this->Foo(5);}有效。然而,这个表达式被gcc/g++4拒绝。最后,我找到了解决办法。只需将默认构造函数更改为Foo(){Foo(5);}进入Foo(){

c++ - 我是否需要删除使用 new 和 placement 构造的对象

classFoo{//somememberpublic:intbar;}intmain(){char*buffer=newchar[100];Foo*f=new(buffer)Foo();//doihavetodeletef;//orisdelete[]buffer;//enough}当然,如果删除Foo对系统有一些重大影响,我必须删除它,但可以说它是一个简单的存储对象,我将其完全放在缓冲区内并且没有确实删除了一些其他东西的析构函数。我是否必须删除一个放置在新内部的对象是否足以删除缓冲区?如果我必须对缓冲区内的每个对象调用delete,为什么我必须这样做吗?我读到:what-uses-