根据我的研究,我知道x86 cpu具有强大的内存模型,这意味着写入不会被重新排序.这使释放锁定安全.对于具有弱内存模型的Itanium cpu,情况并非如此.
我理解易失性,内存障碍和执行重新排序原则.
理想情况下,如果cpu是Itanium,则在关键点插入内存屏障,但如果是x86则不插入内存屏障.是否有可能动态地执行此 *** 作,就像JIT处理的运行时编译器指令一样?
如果没有,我意识到我需要为这两个平台分别构建.在这种情况下,如果没有2套C#文件,而只是简单地更改目标,最优雅的方法是什么?
解决方法 回答你的主要问题;我认为目前不可能将CIL指令有条件地编译为基于平台的机器指令(除了JIT编译器中的内容之外).从一组源创建两个(或更多)构建的主要工具仍然是preprocessor directives.
总结以上是内存溢出为你收集整理的c# – 根据CPU架构,运行时是否可以有条件代码?全部内容,希望文章能够帮你解决c# – 根据CPU架构,运行时是否可以有条件代码?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)