Esta pregunta puede parecer pedante o simplemente tonta, pero ¿cuál es su práctica para la carcasa de camello cuando se trata de acrónimos? ¿Insiste en que todo, incluso los acrónimos, deben estar revestidos de camello o hacen una excepción para los acrónimos? Las explicaciones también serían geniales. No estoy seguro de cómo esta práctica afecta a las características IDE (autocompletar) o cuáles son los estándares de la industria.acrónimos de la caja del camello?
Respuesta
para C#, echa un vistazo a Microsoft's guidelines:
No capitalizar los dos personajes de acrónimos de dos caracteres, excepto la primera palabra de un identificador camello entubado .
una propiedad denominada DBRate es un ejemplo de un corto acrónimo (DB) se utiliza como la primera palabra de una identificador entubado-Pascal . Un parámetro denominado ioChannel es un ejemplo de un acrónimo corto (IO) utilizado como la primera palabra de un identificador camel-cassette.
No mayúscula sólo el primer carácter de siglas con tres o más caracteres , excepto la primera palabra de un identificador de camello entubado.
una clase llamada XmlWriter es un ejemplo de una larga sigla usada como la primera palabra de un identificador de entubado-Pascal. Un parámetro llamado htmlReader es un ejemplo de un acrónimo largo utilizado como la primera palabra de un identificador camel-cased .
no capitalizan cualquiera de los caracteres de las siglas, lo su longitud, al comienzo de un identificador de camello entubado .
un parámetro denominado xmlStream es un ejemplo de un acrónimo de largo (XML) utilizado como la primera palabra de una identificador de camello entubado. Un parámetro denominado dbServerName es un ejemplo de un acrónimo corto (db) utilizado como la primera palabra de un identificador camel-cassette.
gracias! eso ayuda. – stevebot
veo que esto está etiquetado para C# y java, pero las pautas de estilo van a ser diferentes para cada una. –
Una directriz adicional es: si el acrónimo se deriva de los nombres de personas, entonces manténgalo todo en mayúscula. Es "RSACryptoServiceProvider", no "RsaCryptoServiceProvider". ¿Te gustaría ser quien le diga a Shamir o Adelman que no califican una letra mayúscula? Yo creo que no. :-) –
No tenemos difícil regla & rápido, pero generalmente no acrónimos de camello. Algunos con más de tres letras son pero la mayoría no lo son.
preferencia personal.
Tiendo a hacerlo simplemente porque no se combina bien con otras palabras, como, XMLHTTPParser
, en comparación con XmlHttpParser
. Haz lo que te haga sentir bien, pero hazlo de una manera estándar.
Esto es lo que me gusta, y esto es para Java: las clases comienzan con mayúsculas, los campos con minúsculas y los acrónimos no afectan a eso.Esto nos lleva a las cosas que se ven así,
UrlConnection urlConnection;
El problema es que si se intenta aplicar una regla en la que siempre mayúsculas siglas, o incluso la primera letra de un acrónimo, independientemente de que sea un campo o una clase de nombre, a hacer las cosas extrañas como,
URLConnection URLConnection; // huh?
En otras palabras, el campo comienza con el artículo minúsculas contradice con una regla siglas en mayúsculas hipotético. No puedes aplicarlos a ambos.
Incluso el SDK Java tiene ejemplos de ambos, dentro de un único nombre genérico: HttpURLConnection
. Se podría pensar que sería ya sea HTTPURLConnection
o HttpUrlConnection
.
¿Algún ejemplo en jdk-source? –
ver arriba: 'HttpURLConnection'. el acrónimo 'Http' está encasillado en camello pero' URL' no. –
En general, nuestras siglas se PascalCased o CamelCased ya que la mayoría han declarado.
Algunas excepciones:
Si un acrónimo utilizado en un nombre de miembro es bien conocido en el negocio para el que se está escribiendo el software, y es un verdadero acrónimo (las letras mayúsculas forman una palabra del diccionario , a diferencia de una inicialización como XML), a menudo lo capitalizamos para evitar confusiones con la palabra del diccionario.
Algunas veces en ORMs que trabajan contra DB existentes, acabo de nombrar la variable mapeada lo mismo que la columna DB, mayúsculas y todo, en lugar de tener que mapear FdicId => FDICID explícitamente en una base de datos sensible a mayúsculas y minúsculas. Esto tiene su lado negativo, como futuros desarrolladores pueden romper en silencio funcionalidad si se sienten con más fuerza que yo que debe ser entubado correctamente, pero no sabía qué.
ID es un poco de un flip-flopper cuando se utiliza en el extremo de un nombre de miembro; Ya sea ID o Id depende del desarrollador que escribe el primer miembro de esa clase o espacio de nombres, y rara vez se revisan.
En general, el tratamiento de siglas el mismo que el caso general palabra es el más intuitivo, por las siguientes razones.
- Ayuda a evitar la memorización de un montón de reglas especiales (ejemplo de ello, las directrices MS arriba)
- El minúsculas y mayúsculas de términos específicos pueden cambiar con el tiempo o entre las interpretaciones personales como con
posix
,unix
,regex
,radar
,scuba
,laser
yemail
- de otro modo, puede obtener visualmente torpe cuando se necesita para hacer frente a (y/o combinar) términos tecnológicos como
miniiOSLayout
,SSHHTTPSSession
,CPUURLLinkC
y schemaeBay (concedieron estas especi ejemplos FIC es poco probable, que ayudan a ilustrar el problema) - que elimina cierta confusión si el idioma utiliza diferentes casos para diferentes cosas, como la capitalización
AClassName
pero noanObjectName
Sí, httpUrl
parece tonto. Pero cuanto más codifique, más probable es que se dé cuenta de los puntos anteriores por su cuenta. Y si bien no es un gran negocio en sí mismo, muchas cosas pequeñas pueden acumularse y crear frustración con su trabajo.
Depende de la longitud de los acrónimos también.
DB ---> ve decente
openDBConnection
HTTP ---> parece extraño
openHTTPCConnection
Aparte de reglas:
legibilidad importa mucho para mí.
La consistencia muestra su esfuerzo en la programación.
Por lo tanto, hazlo consistente y legible.
- 1. Cómo deshabilitar la selección de caja de camello en Eclipse
- 2. Conversión de la caja de camello a la caja de subrayado en rubí
- 3. .NET guidelines: ¿Por qué excepción para acrónimos de dos letras?
- 4. Convención de nomenclatura para Android: minúscula con subrayado vs. caja de camello
- 5. Creación de acrónimos en Python
- 6. StackTrace de camello Contexto onException
- 7. indentación de la caja del interruptor
- 8. Expresión regular para los acrónimos
- 9. IntelliJ: Generar la caja del interruptor
- 10. 0 en la caja del interruptor?
- 11. referencia enum en la caja del interruptor
- 12. ¿Múltiples condiciones en la caja del interruptor?
- 13. La caja del interruptor JS no funciona
- 14. C# Convenciones de nomenclatura para acrónimos
- 15. Expresión dentro de la declaración de la caja del interruptor
- 16. caja del interruptor en XSL
- 17. la caja de autocompletar
- 18. Eclipse: autocompletado de Java Enum de la caja del conmutador
- 19. caja del interruptor con etiqueta de visualización
- 20. Semántica formal del posicionamiento de caja CSS
- 21. explosión UpperCasedCamelCase a la sentencia de camello mayusculas en PHP
- 22. Firefox: ¿interpretación errónea del modelo de caja?
- 23. la conversión de la sombra del descenso del photoshop en la caja de CSS3 sombra
- 24. ¿Cómo puedo cortar (1) palabras en camello?
- 25. Cadena de PascalCase dividida a excepción de los acrónimos
- 26. Alternativa a la caja del conmutador en Java
- 27. Cómo construir acrónimos de una frase en PHP
- 28. Maven SVN ejemplo la caja
- 29. ¿Cuál es la ventaja del modelo de caja W3C en comparación con el modelo de caja IE5?
- 30. ¿Cambiar la caja con caída?
En realidad, la pregunta es pedante * y * tonto. :) – MusiGenesis
En realidad, no es pedante * ni * tonto. [Convenciones de codificación] (http://en.wikipedia.org/wiki/Coding_conventions) existen por una razón. Aunque este es quizás flexible ... Capitalizo solo la primera letra en C# y también .NET. – MasterMastic