static const
значения рассматривают как r-значения точно так же, как enum
в 99% кода, который Вы будете видеть. Постоянным r-значениям никогда не генерировали память для них. Преимущество enum
константы, они не могут стать l-значениями в этом другой 1%. static const
значения безопасны с точки зрения типов и допускают плавания, струны до, и т.д.
, компилятор сделает Foo::Life
l-значение, если ему свяжут память с ним. Обычный способ сделать, который должен взять его адрес. например, &Foo::Life;
Вот тонкий пример, где GCC будет использовать адрес:
int foo = rand()? Foo::Life: Foo::Everthing;
компилятор генерировал использование кода адреса Life
и Everything
. Хуже, это только производит ошибку компоновщика о недостающих адресах для [1 110] и Foo::Everything
. Это поведение является абсолютно стандартным приспосабливанием, хотя, очевидно, нежелательный. Существуют другие особенные методы компилятора, что это может произойти, и все стандартное приспосабливание.
, Как только у Вас есть соответствующий C++ 11 компиляторов, которыми корректный код будет
class Foo {
public:
constexpr size_t Life = 42;
};
, Это, как гарантируют, всегда будет l-значением, и это является безопасным с точки зрения типов, лучшим из обоих миров.
Рассмотрите возможность использования такой функции, как эта:
function createXMLHttpRequest() {
var xmlhttp = false;
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else if(window.ActiveXObject) {
try {
xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {
xmlhttp = false;
}
}
}
return xmlhttp;
};
которая проверяет наличие нового подключаемого модуля XMLHttp в ActiveX или по умолчанию используется старый.
Обновление: попробуйте следующее:
function createXMLHttpRequest()
{
var xmlhttp, bComplete = false;
try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); }
catch (e) { try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); }
catch (e) { try { xmlhttp = new XMLHttpRequest(); }
catch (e) { xmlhttp = false; }}}
if (!xmlhttp) return null;
this.connect = function(sURL, sMethod, sVars, fnDone)
{
if (!xmlhttp) return false;
bComplete = false;
sMethod = sMethod.toUpperCase();
try {
if (sMethod == "GET")
{
xmlhttp.open(sMethod, sURL+"?"+sVars, true);
sVars = "";
}
else
{
xmlhttp.open(sMethod, sURL, true);
xmlhttp.setRequestHeader("Method", "POST "+sURL+" HTTP/1.1");
xmlhttp.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");
}
xmlhttp.onreadystatechange = function(){
if (xmlhttp.readyState == 4 && !bComplete)
{
bComplete = true;
fnDone(xmlhttp);
}};
xmlhttp.send(sVars);
}
catch(z) { return false; }
return true;
};
return this;
}
function getModIndex(val) {
var divEle = "IndexDiv" + val;
var request = createXMLHttpRequest();
if ( !request ) {
alert( request )
return false
}
var callback = function( oXML ) {
document.getElementById( divEle ).innerHTML = oXML.responseText;
}
request.connect(
'../ajax/ajax-GetIndex.php',
'POST',
'id=' + val,
callback
);
}
Можете ли вы попробовать этот код:
function createXMLHttpRequest() {
if (typeof XMLHttpRequest != "undefined") {
return new XMLHttpRequest();
} else if (typeof ActiveXObject != "undefined") {
return new ActiveXObject("Microsoft.XMLHTTP");
} else {
throw new Error("XMLHttpRequest not supported");
}
прямо из jQuery:
return window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") :
new XMLHttpRequest();
Можно попробовать UpperLower case для Microsoft.XMLHTTP, т.е. (Microsoft.XMLHttp) IE8 чрезвычайно чувствителен к регистру
.