过氧化氢是什么| 什么情况下做试管婴儿| 真菌感染什么症状| 有白痰是什么原因| 凤冈锌硒茶属于什么茶| 养胃吃什么水果| 乳糖酶是什么| 吃黄芪有什么好处| 紫外线是什么意思| 梦到打死蛇是什么意思| 艾灸肚脐有什么好处| 螳螂吃什么| 什么什么望外| 2033年是什么年| 为什么总是想吐| 8月12号是什么星座| 干扰素是什么药| 肠胃不舒服吃什么| 二十年是什么婚| 黑裙子配什么鞋子| 你代表什么意思| 出梅是什么意思| 1997年7月1日属什么生肖| 为什么会出现幻觉| 清浅是什么意思| 女人白带多什么原因| 什么补血快| 跛脚是什么意思| 科目三为什么这么难| 正月十九是什么日子| 什么是熬夜| 920是什么意思| 骨转移是什么意思| 疯狂动物城里的狐狸叫什么| 嗓子疼是什么原因引起的| 气短是什么意思| 铁路12306什么时候放票| 痛风什么药止痛最快| 阉割是什么意思| 五行中水是什么颜色| 一直打嗝不止是什么原因| 磨人的小妖精是什么意思| 吃芥末有什么好处| 三不伤害是指什么| 朝鲜为什么那么落后| 什么是天乙贵人| 椭圆形脸适合什么发型| 什么石穿| 老年人出现幻觉是什么原因| nk细胞是什么| 青蛙是什么生肖| 肋间神经炎吃什么药| mlb是什么牌子| 政客是什么意思| 牙疳是什么意思| 疱疹什么症状| 玉子是什么| 不什么下什么的成语| 小孩老是咬手指甲是什么原因| 眼眶疼是什么原因| dunk是什么牌子| 什么草药治肿瘤最佳| 又什么又什么的葡萄| 手上的纹路代表什么| 女人为什么比男人长寿| 什么人适合吃人参| 什么食物含有维生素d| 包皮发炎用什么药| 孝喘吃什么药好| 白面是什么| 脂肪酶是什么| 蜜蜡是什么材料| 直肠ca代表什么病| H 什么意思| 为什么心里老是想着死| 2月24日什么星座| 公务员和事业编有什么区别| 经期适合喝什么汤| ast是什么意思| hpv52高危阳性是什么意思| 湿气重吃什么水果| 活血化瘀吃什么药| 打喷嚏是什么原因| 女人下巴长痘痘是什么原因| 电解水是什么水| 失眠什么药最好| 是什么样的感觉我不懂是什么歌| 吃蒲公英有什么好处| 什么时候有流星| 土猪肉和普通猪肉有什么分别| 3D硬金是什么意思| 梦见死人的场面是什么兆头| 交警支队长是什么级别| 喝什么降血压| 急性中耳炎吃什么药| 脾功能亢进是什么意思| 嗯哼的爸爸叫什么| 吃鸡什么意思| 正官正印是什么意思| 什么东西吃蟑螂| yy是什么意思| 双脚冰凉是什么原因| 井底之蛙是什么意思| 刷题是什么意思| 金卡有什么好处和坏处| 胱抑素c高是什么原因| 卢沟桥事变又称什么| 什么炖鸡好吃| 13点是什么时辰| 类风湿是什么意思| 电饭煲煮粥为什么会溢出来| 海字五行属什么| 晚上睡觉容易醒是什么原因| 离家出走需要准备什么| 下边瘙痒是什么原因| 什么粉一沾就痒还看不出来| 悲智双运什么意思| 最高检检察长什么级别| 鹿参膏有什么作用和功效| 抽动症是什么引起的| 不完全性右束支传导阻滞是什么意思| 8月11日是什么星座| 什么是胆红素| 牙周炎是什么| 身份证最后四位数代表什么| 特首是什么意思| 小鼠吃什么| 菩提子是什么树的种子| 不是什么意思| 为什么结婚| 为什么会有白头发| 平板运动试验阳性是什么意思| 血糖为什么会高| 病毒性结膜炎用什么眼药水| 猫奴是什么意思| 1月21号是什么星座| pcr医学上是什么意思| 贫血缺什么元素| 84年属什么生肖| 宀与什么有关| 小便解不出来是什么原因| 血压偏高喝什么茶| sga是什么意思| 粉色分泌物是什么原因| 人咬人有什么危害| 经常咳嗽是什么原因| 肠粘连是什么原因引起| 胜利在什么| 清创是什么意思| 吃什么补气| 大便偏黑是什么原因| pc是什么材质| 坏肚子吃什么药| 倒置是什么意思| 氨是什么| 属实是什么意思| 儿童乐园有什么好玩的| 丁胺卡那又叫什么药名| 七一年属什么生肖| 破血是什么意思| 鳑鲏吃什么| 穿山甲到底说了什么| 鸡蛋白过敏指的是什么| 西洋参什么时候吃效果最好| 胆囊结石用什么药好| oct是什么意思| 异性是什么意思| 床上用品四件套都有什么| 支气管炎吃什么药最有效| 男性吃什么可以壮阳| c罗穿什么足球鞋| 什么是深海鱼| 戒断反应什么意思| 女人为什么会怀孕| 什么是华人| 一诺千金是什么生肖| 货比三家是什么意思| 血脂高有什么症状表现| burberry是什么品牌| 绿茶女是什么意思| 房颤是什么意思| 阴湿是什么意思| 朗朗乾坤下一句是什么| 螳螂捕蝉黄雀在后是什么意思| 燕麦色是什么颜色| 健康证有什么用| fl是什么| 蒲公英泡水喝有什么功效| 杀青了是什么意思| 办理生育津贴需要什么资料| 高大上的意思是什么| 田五行属性是什么| 傻白甜什么意思| 抗环瓜氨酸肽抗体高是什么意思| 车前草有什么作用| 乙肝抗体1000代表什么| 碳酸钙是什么| 分别心是什么意思| bun什么意思| 男人不尊重你说明什么| 冰激凌和冰淇淋有什么区别| 什么人容易得心梗| 菜板买什么材质的好| 吃什么可以抗衰老| 梦见买鸡蛋是什么意思周公解梦| 膈肌痉挛吃什么药| 为什么想吐却吐不出来| 蟹柳是什么做的| 大便有点绿色是什么原因| 蚊子会传染什么病| 七月四日是什么星座| 孕酮低是什么原因| 鸡蛋可以炒什么菜| 为什么尿黄| 甲状腺炎吃什么药好得快| 肺结节不能吃什么食物| 板带是什么| 绿壳鸡蛋是什么鸡生的| 授记是什么意思| 女人得性疾病什么症状| 丙类药一般是什么药| 贾琏为什么叫二爷| dob值阳性是什么意思| 市公安局局长是什么级别| 看灰指甲挂什么科| 三唑仑是什么| 疱疹性咽峡炎是什么引起的| 什么地赞叹| 鹿鞭是什么| 后壁和前壁有什么区别| jimmy是什么意思| 人参果不能和什么一起吃| 积食发烧吃什么药| 失眠看什么科最好| 男人手大代表什么| 九门提督相当于现在什么官| 什么时间运动减肥效果最好| 三月是什么月| 瘦肉精是什么| 七月九号是什么日子| 看胃挂什么科室| 十二指肠霜斑样溃疡是什么意思| b型钠尿肽测定是什么检查| 梦见给死人烧纸钱是什么意思| 面诊是什么意思| 心驰神往是什么意思| 常吃南瓜子有什么好处和坏处| 小肚子痛吃什么药| 谷胱甘肽是什么| hpv73阳性是什么意思| 牙疼吃什么菜降火最快| 台湾三小是什么意思| 夜间睡觉流口水是什么原因| 8月15号什么星座| 胃不好能吃什么| 乙醚是什么| 1979年出生属什么生肖| 1992年属什么| 四季春属于什么茶| 脂肪肝看什么指标| 心脏病有什么症状表现| 肾结石看什么科| 六月一日是什么星座| 胆囊切除对身体有什么影响| 百度Jump to content

万马奔腾!《攻城三国》新版本“神兽纵横”正式开启

From Wikipedia, the free encyclopedia
This is the current revision of this page, as edited by Onel5969 (talk | contribs) at 09:43, 29 July 2025 (Disambiguating links to Object-orientation (link changed to Object-oriented programming) using DisamAssist.). The present address (URL) is a permanent link to this version.
(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)
The standard type hierarchy of Python 3
百度 株洲石峰公园、洪江古城嵩云山国家森林公园、张家界王家坪镇金源樱花示范基地、湖南四明山森林公园(衡阳)等地的樱花,每年也吸引了众多游客前往观赏。

In computer science and computer programming, a data type (or simply type) is a collection or grouping of data values, usually specified by a set of possible values, a set of allowed operations on these values, and/or a representation of these values as machine types.[1] A data type specification in a program constrains the possible values that an expression, such as a variable or a function call, might take. On literal data, it tells the compiler or interpreter how the programmer intends to use the data. Most programming languages support basic data types of integer numbers (of varying sizes), floating-point numbers (which approximate real numbers), characters and Booleans.[2][3]

Concept

[edit]

A data type may be specified for many reasons: similarity, convenience, or to focus the attention. It is frequently a matter of good organization that aids the understanding of complex definitions. Almost all programming languages explicitly include the notion of data type, though the possible data types are often restricted by considerations of simplicity, computability, or regularity. An explicit data type declaration typically allows the compiler to choose an efficient machine representation, but the conceptual organization offered by data types should not be discounted.[4]

Different languages may use different data types or similar types with different semantics. For example, in the Python programming language, int represents an arbitrary-precision integer which has the traditional numeric operations such as addition, subtraction, and multiplication. However, in the Java programming language, the type int represents the set of 32-bit integers ranging in value from ?2,147,483,648 to 2,147,483,647, with arithmetic operations that wrap on overflow. In Rust this 32-bit integer type is denoted i32 and panics on overflow in debug mode.[5]

Most programming languages also allow the programmer to define additional data types, usually by combining multiple elements of other types and defining the valid operations of the new data type. For example, a programmer might create a new data type named "complex number" that would include real and imaginary parts, or a color data type represented by three bytes denoting the amounts each of red, green, and blue, and a string representing the color's name.

Data types are used within type systems, which offer various ways of defining, implementing, and using them. In a type system, a data type represents a constraint placed upon the interpretation of data, describing representation, interpretation and structure of values or objects stored in computer memory. The type system uses data type information to check correctness of computer programs that access or manipulate the data. A compiler may use the static type of a value to optimize the storage it needs and the choice of algorithms for operations on the value. In many C compilers the float data type, for example, is represented in 32 bits, in accord with the IEEE specification for single-precision floating point numbers. They will thus use floating-point-specific microprocessor operations on those values (floating-point addition, multiplication, etc.).

Definition

[edit]

Parnas, Shore & Weiss (1976) identified five definitions of a "type" that were used—sometimes implicitly—in the literature:

Syntactic
A type is a purely syntactic label associated with a variable when it is declared. Although useful for advanced type systems such as substructural type systems, such definitions provide no intuitive meaning of the types.
Representation
A type is defined in terms of a composition of more primitive types—often machine types.
Representation and behaviour
A type is defined as its representation and a set of operators manipulating these representations.
Value space
A type is a set of possible values which a variable can possess. Such definitions make it possible to speak about (disjoint) unions or Cartesian products of types.
Value space and behaviour
A type is a set of values which a variable can possess and a set of functions that one can apply to these values.

The definition in terms of a representation was often done in imperative languages such as ALGOL and Pascal, while the definition in terms of a value space and behaviour was used in higher-level languages such as Simula and CLU. Types including behavior align more closely with object-oriented models, whereas a structured programming model would tend to not include code, and are called plain old data structures.

Classification

[edit]

Data types may be categorized according to several factors:

  • Primitive data types or built-in data types are types that are built-in to a language implementation. User-defined data types are non-primitive types. For example, Java's numeric types are primitive, while classes are user-defined.
  • A value of an atomic type is a single data item that cannot be broken into component parts. A value of a composite type or aggregate type is a collection of data items that can be accessed individually.[6] For example, an integer is generally considered atomic, although it consists of a sequence of bits, while an array of integers is certainly composite.
  • Basic data types or fundamental data types are defined axiomatically from fundamental notions or by enumeration of their elements. Generated data types or derived data types are specified, and partly defined, in terms of other data types. All basic types are atomic.[7] For example, integers are a basic type defined in mathematics, while an array of integers is the result of applying an array type generator to the integer type.

The terminology varies - in the literature, primitive, built-in, basic, atomic, and fundamental may be used interchangeably.[8]

Examples

[edit]

Machine data types

[edit]

All data in computers based on digital electronics is represented as bits (alternatives 0 and 1) on the lowest level. The smallest addressable unit of data is usually a group of bits called a byte (usually an octet, which is 8 bits). The unit processed by machine code instructions is called a word (as of 2025, typically 64 bits).

Machine data types expose or make available fine-grained control over hardware, but this can also expose implementation details that make code less portable. Hence machine types are mainly used in systems programming or low-level programming languages. In higher-level languages most data types are abstracted in that they do not have a language-defined machine representation. The C programming language, for instance, supplies types such as Booleans, integers, floating-point numbers, etc., but the precise bit representations of these types are implementation-defined. The only C type with a precise machine representation is the char type that represents a byte.[9]

Boolean type

[edit]

The Boolean type represents the values true and false. Although only two values are possible, they are more often represented as a byte or word rather as a single bit as it requires more machine instructions to store and retrieve an individual bit. Many programming languages do not have an explicit Boolean type, instead using an integer type and interpreting (for instance) 0 as false and other values as true. Boolean data refers to the logical structure of how the language is interpreted to the machine language. In this case a Boolean 0 refers to the logic False. True is always a non zero, especially a one which is known as Boolean 1.

Numeric types

[edit]

Almost all programming languages supply one or more integer data types. They may either supply a small number of predefined subtypes restricted to certain ranges (such as short and long and their corresponding unsigned variants in C/C++); or allow users to freely define subranges such as 1..12 (e.g. Pascal/Ada). If a corresponding native type does not exist on the target platform, the compiler will break them down into code using types that do exist. For instance, if a 32-bit integer is requested on a 16 bit platform, the compiler will tacitly treat it as an array of two 16 bit integers.

Floating point data types represent certain fractional values (rational numbers, mathematically). Although they have predefined limits on both their maximum values and their precision, they are sometimes misleadingly called reals (evocative of mathematical real numbers). They are typically stored internally in the form a × 2b (where a and b are integers), but displayed in familiar decimal form.

Fixed point data types are convenient for representing monetary values. They are often implemented internally as integers, leading to predefined limits.

For independence from architecture details, a Bignum or arbitrary precision numeric type might be supplied. This represents an integer or rational to a precision limited only by the available memory and computational resources on the system. Bignum implementations of arithmetic operations on machine-sized values are significantly slower than the corresponding machine operations.[10]

Enumerations

[edit]

The enumerated type has distinct values, which can be compared and assigned, but which do not necessarily have any particular concrete representation in the computer's memory; compilers and interpreters can represent them arbitrarily. For example, the four suits in a deck of playing cards may be four enumerators named CLUB, DIAMOND, HEART, SPADE, belonging to an enumerated type named suit. If a variable V is declared having suit as its data type, one can assign any of those four values to it. Some implementations allow programmers to assign integer values to the enumeration values, or even treat them as type-equivalent to integers.

String and text types

[edit]

Strings are a sequence of characters used to store words or plain text, most often textual markup languages representing formatted text. Characters may be a letter of some alphabet, a digit, a blank space, a punctuation mark, etc. Characters are drawn from a character set such as ASCII or Unicode. Character and string types can have different subtypes according to the character encoding. The original 7-bit wide ASCII was found to be limited, and superseded by 8, 16 and 32-bit sets, which can encode a wide variety of non-Latin alphabets (such as Hebrew and Chinese) and other symbols. Strings may be of either variable length or fixed length, and some programming languages have both types. They may also be subtyped by their maximum size.

Since most character sets include the digits, it is possible to have a numeric string, such as "1234". These numeric strings are usually considered distinct from numeric values such as 1234, although some languages automatically convert between them.

Union types

[edit]

A union type definition will specify which of a number of permitted subtypes may be stored in its instances, e.g. "float or long integer". In contrast with a record, which could be defined to contain a float and an integer, a union may only contain one subtype at a time.

A tagged union (also called a variant, variant record, discriminated union, or disjoint union) contains an additional field indicating its current type for enhanced type safety.

Algebraic data types

[edit]

An algebraic data type (ADT) is a possibly recursive sum type of product types. A value of an ADT consists of a constructor tag together with zero or more field values, with the number and type of the field values fixed by the constructor. The set of all possible values of an ADT is the set-theoretic disjoint union (sum), of the sets of all possible values of its variants (product of fields). Values of algebraic types are analyzed with pattern matching, which identifies a value's constructor and extracts the fields it contains.

If there is only one constructor, then the ADT corresponds to a product type similar to a tuple or record. A constructor with no fields corresponds to the empty product (unit type). If all constructors have no fields then the ADT corresponds to an enumerated type.

One common ADT is the option type, defined in Haskell as data Maybe a = Nothing | Just a.[11]

Data structures

[edit]

Some types are very useful for storing and retrieving data and are called data structures. Common data structures include:

  • An array (also called vector, list, or sequence) stores a number of elements and provides random access to individual elements. The elements of an array are typically (but not in all contexts) required to be of the same type. Arrays may be fixed-length or expandable. Indices into an array are typically required to be integers (if not, one may stress this relaxation by speaking about an associative array) from a specific range (if not all indices in that range correspond to elements, it may be a sparse array).
  • Record (also called tuple or struct) Records are among the simplest data structures. A record is a value that contains other values, typically in fixed number and sequence and typically indexed by names. The elements of records are usually called fields or members.
  • An object contains a number of data fields, like a record, and also offers a number of subroutines for accessing or modifying them, called methods.
  • the singly linked list, which can be used to implement a queue and is defined in Haskell as the ADT data List a = Nil | Cons a (List a), and
  • the binary tree, which allows fast searching, and can be defined in Haskell as the ADT data BTree a = Nil | Node (BTree a) a (BTree a)[12]

Abstract data types

[edit]

An abstract data type is a data type that does not specify the concrete representation of the data. Instead, a formal specification based on the data type's operations is used to describe it. Any implementation of a specification must fulfill the rules given. For example, a stack has push/pop operations that follow a Last-In-First-Out rule, and can be concretely implemented using either a list or an array. Abstract data types are used in formal semantics and program verification and, less strictly, in design.

Pointers and references

[edit]

The main non-composite, derived type is the pointer, a data type whose value refers directly to (or "points to") another value stored elsewhere in the computer memory using its address. It is a primitive kind of reference. (In everyday terms, a page number in a book could be considered a piece of data that refers to another one). Pointers are often stored in a format similar to an integer; however, attempting to dereference or "look up" a pointer whose value was never a valid memory address would cause a program to crash. To ameliorate this potential problem, a pointer type is typically considered distinct from the corresponding integer type, even if the underlying representation is the same.

Function types

[edit]

Functional programming languages treat functions as a distinct datatype and allow values of this type to be stored in variables and passed to functions. Some multi-paradigm languages such as JavaScript also have mechanisms for treating functions as data.[13] Most contemporary type systems go beyond JavaScript's simple type "function object" and have a family of function types differentiated by argument and return types, such as the type Int -> Bool denoting functions taking an integer and returning a Boolean. In C, a function is not a first-class data type but function pointers can be manipulated by the program. Java and C++ originally did not have function values but have added them in C++11 and Java 8.

Type constructors

[edit]

A type constructor builds new types from old ones, and can be thought of as an operator taking zero or more types as arguments and producing a type. Product types, function types, power types and list types can be made into type constructors.

Quantified types

[edit]

Universally-quantified and existentially-quantified types are based on predicate logic. Universal quantification is written as or forall x. f x and is the intersection over all types x of the body f x, i.e. the value is of type f x for every x. Existential quantification written as or exists x. f x and is the union over all types x of the body f x, i.e. the value is of type f x for some x.

In Haskell, universal quantification is commonly used, but existential types must be encoded by transforming exists a. f a to forall r. (forall a. f a -> r) -> r or a similar type.

Refinement types

[edit]

A refinement type is a type endowed with a predicate which is assumed to hold for any element of the refined type. For instance, the type of natural numbers greater than 5 may be written as

Dependent types

[edit]

A dependent type is a type whose definition depends on a value. Two common examples of dependent types are dependent functions and dependent pairs. The return type of a dependent function may depend on the value (not just type) of one of its arguments. A dependent pair may have a second value of which the type depends on the first value.

Intersection types

[edit]

An intersection type is a type containing those values that are members of two specified types. For example, in Java the class Boolean implements both the Serializable and the Comparable interfaces. Therefore, an object of type Boolean is a member of the type Serializable & Comparable. Considering types as sets of values, the intersection type is the set-theoretic intersection of and . It is also possible to define a dependent intersection type, denoted , where the type may depend on the term variable .[14]

Meta types

[edit]

Some programming languages represent the type information as data, enabling type introspection and reflective programming (reflection). In contrast, higher order type systems, while allowing types to be constructed from other types and passed to functions as values, typically avoid basing computational decisions on them.[citation needed]

Convenience types

[edit]

For convenience, high-level languages and databases may supply ready-made "real world" data types, for instance times, dates, and monetary values (currency).[15][16] These may be built-in to the language or implemented as composite types in a library.[17]

See also

[edit]

References

[edit]
  1. ^ Parnas, Shore & Weiss 1976.
  2. ^ type at the Free On-line Dictionary of Computing
  3. ^ Shaffer, C. A. (2011). Data Structures & Algorithm Analysis in C++ (3rd ed.). Mineola, NY: Dover. 1.2. ISBN 978-0-486-48582-9.
  4. ^ Scott, Dana (September 1976). "Data Types as Lattices". SIAM Journal on Computing. 5 (3): 540–541. doi:10.1137/0205037.
  5. ^ "Rust RFCs - Integer Overflow". The Rust Programming Language. 12 August 2022.
  6. ^ Dale, Nell B.; Weems, Chip; Headington, Mark R. (1998). Programming in C++. Jones & Bartlett Learning. p. 349. ISBN 978-0-7637-0537-4.
  7. ^ ISO/IEC 11404, 6.4
  8. ^ BHATNAGAR, SEEMA (19 August 2008). TEXTBOOK OF COMPUTER SCIENCE FOR CLASS XI. PHI Learning Pvt. Ltd. p. 182. ISBN 978-81-203-2993-5.
  9. ^ "SC22/WG14 N2176" (PDF). Wayback Machine. Section 6.2.6.2. Archived from the original (PDF) on 30 December 2018. Which of [sign and magnitude, two's complement, one's complement] applies is implementation-defined
  10. ^ "Integer benchmarks — mp++ 0.27 documentation". bluescarni.github.io.
  11. ^ "6 Predefined Types and Classes". www.haskell.org. Retrieved 2025-08-07.
  12. ^ Suresh, S P. "Programming in Haskell: Lecture 22" (PDF). Chennai Mathematical Institute. Retrieved 10 August 2022.
  13. ^ Flanagan, David (1997). "6.2 Functions as Data Types". JavaScript: the definitive guide (2nd ed.). Cambridge: O'Reilly & Associates. ISBN 9781565922341.
  14. ^ Kopylov, Alexei (2003). "Dependent intersection: A new way of defining records in type theory". 18th IEEE Symposium on Logic in Computer Science. LICS 2003. IEEE Computer Society. pp. 86–95. CiteSeerX 10.1.1.89.4223. doi:10.1109/LICS.2003.1210048.
  15. ^ West, Randolph (27 May 2020). "How SQL Server stores data types: money". Born SQL. Retrieved 28 January 2022. Some time ago I described MONEY as a "convenience" data type which is effectively the same as DECIMAL(19,4), [...]
  16. ^ "Introduction to data types and field properties". support.microsoft.com. Retrieved 28 January 2022.
  17. ^ Wickham, Hadley (2017). "16 Dates and times". R for data science: import, tidy, transform, visualize, and model data. Sebastopol, CA. ISBN 978-1491910399. Retrieved 28 January 2022.{{cite book}}: CS1 maint: location missing publisher (link)

Further reading

[edit]
[edit]
正月初九是什么星座 凉粉果什么时候成熟 间接胆红素偏高什么意思 乌龟最喜欢吃什么 龟粮什么牌子的好
为什么游戏 小孩瘦小不长肉是什么原因 请产假需要什么材料 淋漓不尽是什么意思 修为是什么意思
钓鲈鱼用什么饵最好 zgo手表是什么牌子 笑是什么意思 人脉是什么意思 胆疼是什么原因
栀是什么意思 精神病是什么意思 做亲子鉴定需要什么材料 馊主意是什么意思 桑葚干和什么搭配泡水
褪黑素有什么副作用gysmod.com 月经期同房有什么危害qingzhougame.com 学生早餐吃什么方便又营养hcv9jop3ns9r.cn 双插头是什么意思mmeoe.com 熔炉是什么意思hcv8jop2ns8r.cn
脚底疼痛是什么原因hcv9jop6ns4r.cn 眉尾有痣代表什么onlinewuye.com 炖牛肉放什么调料好吃hcv8jop7ns4r.cn 心动过缓是什么意思hcv9jop7ns4r.cn 第二职业干点什么好呢hcv9jop8ns1r.cn
性格好是什么意思adwl56.com 尿酸过高是什么原因hcv9jop2ns6r.cn 梦见吃豆腐是什么意思jiuxinfghf.com 月经有黑色血块是什么原因hcv7jop4ns5r.cn cm和mm有什么区别hcv8jop4ns0r.cn
抓阄什么意思hcv9jop4ns6r.cn 先考是什么意思hcv8jop3ns0r.cn 医生会诊是什么意思hcv9jop7ns4r.cn 乐观是什么意思hcv8jop9ns7r.cn angelababy是什么意思hcv8jop5ns2r.cn
百度