由于AS3中的URLloader,嵌套函数调用的运行顺序延迟/改变了?(Running-order of nested function-calls delayed/altered due to URLloader in AS3?)
首先:英语不是我的第一语言。 ;-)
我正在编译以下代码:
var sqldata:String; function sql(saveorload,sqlstring) { var sqlloader = new URLLoader(); var sqlrequest = new URLRequest("http://***/sql.php"); sqlrequest.method = URLRequestMethod.POST; sqlloader.addEventListener(Event.COMPLETE, sqldonetrace); var variables:URLVariables = new URLVariables(); variables.sqlm = saveorload; variables.sqlq = sqlstring; sqlrequest.data = variables; sqlloader.load(sqlrequest); } function sqldonetrace(e:Event) { sqldata = e.target.data; } sql("1","SELECT * FROM songs WHERE `flag2` LIKE '0'"); trace (sqldata);
所以,问题出现了:“sqldata”被追踪为“null”。 AS3似乎运行“sql”,然后“跟踪”然后“sqldone”,但我需要sql - > sqldone - > trace ...我不能把trace-command放在sqldone函数中因为它存储了as * .as并在我的.swf中的不同点加载,并不总是只跟踪一个trace-command。
脚本中的任何想法/提示/缺陷?
First of all: English is not my first language. ;-)
I am compiling the following code:
var sqldata:String; function sql(saveorload,sqlstring) { var sqlloader = new URLLoader(); var sqlrequest = new URLRequest("http://***/sql.php"); sqlrequest.method = URLRequestMethod.POST; sqlloader.addEventListener(Event.COMPLETE, sqldonetrace); var variables:URLVariables = new URLVariables(); variables.sqlm = saveorload; variables.sqlq = sqlstring; sqlrequest.data = variables; sqlloader.load(sqlrequest); } function sqldonetrace(e:Event) { sqldata = e.target.data; } sql("1","SELECT * FROM songs WHERE `flag2` LIKE '0'"); trace (sqldata);
So, here comes the problem: "sqldata" is traced as "null". AS3 seems to run "sql", then "trace" and then "sqldone", but i would need sql -> sqldone -> trace... I can't put the trace-command in the sqldone-function because it is stored as *.as and loaded at different points in my .swf and not always followed by only a trace-command.
Any Ideas/hints/flaws in script?
原文:https://stackoverflow.com/questions/16153739
最满意答案
教程在幻灯片3中说,“所有数组都是(双重)类型”,这意味着 - 通常用于不同类型 - 你不能在两种数组类型之间进行分配; 所以是的,你需要一个循环。
有一些“聪明”的方法,例如,未经检查的转换; 但是,真的,不要去那里!
The tutorial says, on slide 3, that "all arrays are (doubly) typed", which means that - as usual for different types - you can't assign between your two array types; so yes, you need a loop.
There are "clever" ways using, for example, unchecked conversion; but, really, don't go there!
相关问答
更多-
Ada枚举类型范围(Ada Enumerated Type Range)[2023-12-08]
对于子类型, 'pos将返回与基类型相同的值(我相信分别为1..4和2..3)。 亚型并不是真正的新型和不同类型,尽管它们是相同的旧型,但对其可能的值有一些额外的限制。 但应该指出的是,这些值是在场景下分配的。 除非您使用'val 'pos和'pos属性,或者您正在与Ada(或硬件)之外编写的代码进行交互,否则它确实应该对您没有任何影响 。 另外,如果它最终成为问题,你应该知道情况实际上要复杂得多。 'pos和'val不会返回编译器在生成代码时使用这些枚举值的实际位值。 他们只是返回他们的“序位”; 他们偏 ... -
Ada类型声明语义(Ada Type Declaration Semantics)[2023-10-22]
在第一个声明中,声明了一个与Integer不同的新类型,但是从它继承了一些属性(例如原始函数和运算符,不是那么重要)。 对于每一个实际问题,在这种情况下abc和def类型在语义上是等价的。 但是,如果您对基本类型进行了基本操作,则会有所不同。 在这种情况下,你不能真的认为范围的边界有类型,但是如果有基类型,它们必须满足在基类型范围内的限制。 现在xyz简直是不正确的,整数在这里没有任何意义。 它可能意味着两件事: 你真的想声明一个从整数派生的新类型。 在这种情况下,你错过了新的关键字。 你想声明一个整型的子 ... -
你不能拥有一系列不受约束的元素。 一些替代品: 使用不定矢量。 (好!) 创建一个对您的不定类型的访问数组。 (坏!) You can't have an array of unconstrained elements. Some alternatives: Use an indefinite vector. (Good!) Create an array of access to your indefinite type. (Bad!)
-
查看Debian / Jessie中libplplot-ada1-dev软件包提供的源文件,可以在Ada 95版本或Ada 2005版本中提供软件包PLPlot_Auxilary 。 Ada 2005版本使用Ada数字包,而Ada 95版本则不使用。 Looking in the source files provided by the libplplot-ada1-dev package in Debian/Jessie, it looks like package PLPlot_Auxilary can ...
-
在Ada中复制相同类型和大小但不同索引类型的数组(Copy arrays of same type and size but different index type in Ada)[2021-12-07]
教程在幻灯片3中说,“所有数组都是(双重)类型”,这意味着 - 通常用于不同类型 - 你不能在两种数组类型之间进行分配; 所以是的,你需要一个循环。 有一些“聪明”的方法,例如,未经检查的转换; 但是,真的,不要去那里! The tutorial says, on slide 3, that "all arrays are (doubly) typed", which means that - as usual for different types - you can't assign between y ... -
数组的问题在于,在所有表达式中(除了传递给sizeof和一元&运算符时),它们都转换为指向其第一个元素的指针。 所以,假设你有: int arr1[10]; int arr2[10]; ... 然后,如果你写了类似的东西 arr1 = arr2; 你实际上正在尝试这样做: arr1 = &arr2[0]; 或这个: &arr1[0] = &arr2[0]; 在这两种情况下,您都遇到阻止编译代码的问题。 在前一种情况下,您试图在两个不兼容的类型(数组vs指针)之间进行分配,而在后一种情况下,您试图修改 ...
-
ADA:多项任务(ADA: multiple tasks)[2023-11-15]
这是对原始答案的重写,现在我们知道有问题的任务类型是有区别的。 您通过“判别式”将值传递给每个任务而没有默认值,这使得任务类型不受约束; 如果没有为判别式提供值,则无法声明该类型的对象(并且提供默认值将无济于事,因为一旦创建了对象,则无法更改判别式)。 一种常见的方法是使用访问类型: with Ada.Integer_Text_IO; with Ada.Text_IO; procedure Maciek is task type T (Param : Integer); type T_P is ... -
这有点低级和重复性,但也许你可以创建一个小程序(甚至可以在Ada中!)来生成类似的东西 with Ada.Text_IO; use Ada.Text_IO; procedure Lambdabeta is F1 : aliased constant String := "res/0.file"; F2 : aliased constant String := "res/some_more/complicated/file.name"; type Strings is array (Posi ...
-
您的AU定义为以1的下限开始(范围为1..10的匿名数组子类型)。 这永远不会改变。 对于无约束的结果(c和d),您应该分配一个新变量,如下所示: declare AU_c : TU := AU(6..10) & AU(1..5); AU_d : TU := AU(6) & AU(7..10)& AU(1..5); begin -- your Put/Put_Lines here end; Your AU is defined to start with lower bound of 1 ...
-
Ada可以使用动态固定字符串,而不使用Unbounded_String或Containers,或分配和指针,尽管这些是选项。 使这成为可能的见解是,字符串可以在声明时从其初始化表达式中获取其大小 - 但该声明可以在循环内部,因此每次循环时它都会重新执行。 你不能总是构建一个程序,所以这是有道理的,虽然它可能经常令人惊讶,只需要一点点思考。 另一个特点是,稍后,这些“声明”块可以很容易地重构到程序中。 with Ada.Text_IO; use Ada.Text_IO; procedure Calculat ...