Friday, August 12, 2005

Check out Soma's post about the Nullable<T> DCR we recently implemented...we referred to the project as nullbox internally. This one kept me up at night on a few occassions, but was a lot of fun. :) Huge risk, but based on lots of feedback it was the right thing to do. And the team executed perfectly, nailing our target dates at each step along the way.

I alluded to this work here and here. I was vague and avoided answering probing comments intentionally. Now I can answer them...so ask away!

The core of this change is that the IL box instruction has been modified to recognize Nullable<T>s. For non-Nullables, behavior remains the same; but upon seeing one, it inspects its HasValue property. If HasValue is true, box peeks inside the structure, extracts the T value, and boxes that instead; otherwise, box simply leaves behind a null reference. Obviously, unbox has also been changed to allow nulls to be unboxed back into Nullable<T> structures. This had a rippling effect in the CLR codebase and also required changes to late-bound semantics to mimic the static case.

The result is that given

int? x = null;
object y = x;

both expressions

x == null
y == null

evaluate to true. And furthermore, given

bool F<T>(T t) {
    return t == null;
}

the following expressions

F(x)
F(y)

also evaluate to true.

I intend to post a more detailed summary of the DCR over the coming week[s].

8/12/2005 9:18:30 AM (Pacific Daylight Time, UTC-07:00)  #   
Tracked by:
"Issues with nullable types fixed!!!!" (marklio) [Trackback]
"Boxed Nullable" (Managed from down under) [Trackback]
"Nullables now an intrinsic type" (James Kovacs' Weblog) [Trackback]
"Boxing Nullable and verification" (`(joe (@ (version "2.0")) ,(mk-blog))) [Trackback]
"Rotor (SSCLI) 2.0 is available!" (Generalities & Details: Adventures in the Hig... [Trackback]
http://www.google.com/search?q=aqxajckm [Pingback]
http://bf1942.gametrack.org/statssig/xanax.htm [Pingback]
http://www.sm-contacts.com/smchat/images/phpbb.diazepam.htm [Pingback]
http://www.sm-contacts.com/smchat/images/phpbb.soma.htm [Pingback]
http://alternative.lv/img/ambien.htm [Pingback]
http://dermanities.com/images/viagra.php [Pingback]
http://banfun.com/image/tramadol.htm [Pingback]
http://www.kutdiak.hu/upload/adipex.htm [Pingback]
http://www.aprint4all.com/images/xanax.htm [Pingback]
http://www.azk.pl/reading/ativanlorazepam.htm [Pingback]
http://english.tpf.hu/upload/phentermine.htm [Pingback]
http://jouvence.com/img/orderpropecia.htm [Pingback]
http://classicvanhalen.com/backup/tramadolhcl.htm [Pingback]
http://soargbsc.com/FlightReports/ativan.htm [Pingback]
http://www.artakt.co.uk/artaktlibrary/buymeridia.htm [Pingback]
http://gallery.angel-btvs.co.uk/include/ordersoma.htm [Pingback]
http://www.therestaurantshow.co.uk/cms_images/xanaxbuy.htm [Pingback]
http://www.alleydog.com/include/viagra.htm [Pingback]
http://www.artakt.co.uk/artaktlibrary/buyviagraonline.htm [Pingback]
http://www.nevaobject.com/images/cheapcialis.htm [Pingback]
http://www.doggroups.com/cpg132/fioricet.htm [Pingback]
http://mypodcastcenter.com/setup/adipex.htm [Pingback]
http://www.juprowa.com/kittel/forum/message/msg631.html [Pingback]
http://www.gbrothersracing.com/bb/index.cgi?read=42585 [Pingback]
http://www.faragauss.com/wwwboard/messages/38554.html [Pingback]
http://www.allgaeuwebsen.de/cgi-bin/aw_brett.pl?read=195 [Pingback]
http://markitgolf.com/Mark_It/messages/16415.html [Pingback]
http://www.americanrelichunters.com/cgi-bin/indian/webbbs_config.pl/noframes/rea... [Pingback]
http://www.google.com/search?q=gceropfa [Pingback]
http://www.software-exchange.com/nomodomo/phentermineonline.htm [Pingback]
http://www.swapandsave.com/dcforum/pets/1081.shtml [Pingback]
http://www.midnightsuncomputing.com/DuchessForum/messages/1395.shtml [Pingback]
http://worldcupkickoff.com/feed/phenterminedietpill.htm [Pingback]
http://www.mountpleasantlibrary.org/files/xanaxvalium.htm [Pingback]
http://carrefourpme.lesaffaires.com/admin/entente/pdf/carisoprodol.htm [Pingback]
http://www.kubbin.com/calendar/includes/ordertramadol.htm [Pingback]
http://www.jjsblues.net/zencart/images/cheaptramadol.htm [Pingback]
http://tywenzel.com/wp-content/plugins/viagrabuy.htm [Pingback]
http://www.anita-jewelry.com/pioneer/imgs/buysoma.htm [Pingback]
http://www.msx.ch/mb/1/117.html [Pingback]
http://www.discount-printing.com/shop/images/onlinesoma.htm [Pingback]
/blogs/test/archive/2005/08/14/Boxed-Nullable_3C00_T_3E00_-are-now-really-null_2... [Pingback]
/blogs/managedfromdownunder/archive/2005/08/14/Boxed-Nullable_3C00_T_3E00_-are-n... [Pingback]
http://rascast.com/wwwboard/messages/23706.htm [Pingback]
http://www.taylorhoops.com/cgi-local/webbbs_config.pl?read=10813 [Pingback]
http://azminimumwage.com/images/abouttramadol.htm [Pingback]
http://rascast.com/wwwboard/messages/23946.htm [Pingback]
http://industrialcanda.com/ad-photos/buyambien.htm [Pingback]
http://www.lonebuffalo.com/todo/phentermine.htm [Pingback]
http://knighttymes.com/images/ultram.htm [Pingback]
http://creativewebsols.com/support/modules/carisoprodol.htm [Pingback]
http://www.organicvolunteers.com/talk/display_message.asp?mid=11533 [Pingback]
http://www.zumunta.org/wwwboard/messages/17305.html [Pingback]
http://www.mnisose.org/wwwboard/messages/16251.html [Pingback]
http://www.angelsport.de/en/forum/stories/messages/412.html [Pingback]
http://www.thinkofit.com/UserFiles/phenterminedietpill.htm [Pingback]
http://rascast.com/wwwboard/messages/23869.htm [Pingback]
http://www.picassofish.com/dmdocuments/buycheapphentermine.htm [Pingback]
http://hardcore.redclouds.com/enigma/messages/5849.html [Pingback]
http://cvilla.com/aza/ekfetch/xanaxbuy.htm [Pingback]
http://cvilla.com/aza/ekfetch/xanaxonline.htm [Pingback]
http://cornwall-beaches.co.uk/photos/data/discountcialis.htm [Pingback]
http://ericmanherz.com/UserFiles/soma.htm [Pingback]
http://netallianz.com/clients/lotuspreview/uploaded/pharmacyphentermine.htm [Pingback]
http://sarahow.co.uk/blog2/wp-content/cache/xanaxbuy.htm [Pingback]
http://freedomofmind.com/magpierss/cache/genericviagra.htm [Pingback]
http://cobbrealestateblog.com/wp-content/purchasephentermine.htm [Pingback]
http://atlantaintownlofts.com/wp-content/cheapgenericcialis.htm [Pingback]
http://freedomofmind.com/magpierss/cache/tramadol.htm [Pingback]
http://www.google.com/search?q=utnjtyby [Pingback]
http://www.obpa.org/cgi-bin/boards/obpauadmin.cgi?read=1893 [Pingback]
http://diggerhistory.info/forum/images/smiles/cheapphentermine.htm [Pingback]
http://canuckscentral.com/cnghlforum/Images/viagraonline.htm [Pingback]
http://peaktalk.com/archives/img/viagra.htm [Pingback]
http://www.htu.tuwien.ac.at/fachschaften/rpl/planungsstudium/disk_forum/messages... [Pingback]
http://dginteractive.com/cgi-bin/webbbs_config.pl?noframes;read=510 [Pingback]
http://jellybeangifts.co.uk/jshop/files/alprazolam.htm [Pingback]
http://camedwards.com/archives/old/hydrocodoneonline.htm [Pingback]
http://theworldaroundyou.com/images/ultram.htm [Pingback]
http://basement.shoeblogs.com/wp-content/themes/mallow/dietpillphentermine.htm [Pingback]
http://picturezero.com/images/dog/meridia.htm [Pingback]
http://peaktalk.com/archives/img/tramadol.htm [Pingback]
http://giftsnstyles.com/products/big/whatisviagra.htm [Pingback]
http://nicomachus.net/2005/hydrocodone.htm [Pingback]
http://mrsinternational.com/adspics/old/ativan.htm [Pingback]
http://americancity.org/images/phenterminedietpill.htm [Pingback]
http://bridesandbeyond.com/images/old/meridia.htm [Pingback]
http://chicago.creativecanvas.com/images2/buysoma.htm [Pingback]
http://thedailycolumn.com/drafts/archives/adipexonline.htm [Pingback]
http://freedmensbureau.com/testforum/attachments/cialisonline.htm [Pingback]
http://sayitontheweb.com/carrie/albums/images/ultram.htm [Pingback]
http://picturezero.com/images/dog/xanax.htm [Pingback]
http://lopezstudios.com/LS_system/cache/magpie_cache/levitra.htm [Pingback]
http://andrewiandodge.com/wp/images/ativan.htm [Pingback]
http://vinceherman.com/blog/tramadolbuy.htm [Pingback]
http://www.allknightaccess.com/betatesting/transcode/ativan.htm [Pingback]
http://bridesandbeyond.com/images/old/somaonline.htm [Pingback]
http://shutterbabe.org/hwnp/tmp/viagraonline.htm [Pingback]
http://enablingbiz.com/enable/buyxenical.htm [Pingback]
http://www.bdti.com/faq/temp/.sessions/viagra2.htm [Pingback]
http://lopezstudios.com/LS_system/cache/magpie_cache/meridia.htm [Pingback]
http://butuki.com/images/old/soma.htm [Pingback]
http://nicomachus.net/2005/tramadolonline.htm [Pingback]
http://www.allknightaccess.com/betatesting/transcode/buybuyvalium.htm [Pingback]
http://enablingbiz.com/enable/fioricetonline.htm [Pingback]
http://knighttymes.com/uploads/onlinealprazolam.htm [Pingback]
http://rrresorts.com/stats/reports/hydrocodone.htm [Pingback]
http://www.google.com/search?q=wgnnizsj [Pingback]
http://0bounds.com/The-A-List/propecia.htm [Pingback]
http://0bounds.com/The-A-List/ultram.htm [Pingback]
http://5starblogs.com/uploads/buyvicodin.htm [Pingback]
http://heatermeals.com/img/valium.htm [Pingback]
http://brandaface.com/images/soma.htm [Pingback]
http://webih.com/sstatus/images/phentermineadipex.htm [Pingback]
http://net-commish.com/images/dietpillphentermine.htm [Pingback]
http://spaceblue.com/lists/attachments/onlinealprazolam.htm [Pingback]
http://pbase.ca/_stock_pbase/0/xanaxvalium.htm [Pingback]
http://rexhotelvietnam.com/images/old/fioricetonline.htm [Pingback]
http://webih.com/sstatus/images/whatisviagra.htm [Pingback]
http://www.google.com/search?q=lobgakrl [Pingback]
http://miresearch.org/files/buylevitra.htm [Pingback]
http://angliangardener.co.uk/furniture/valiumbuyvalium.htm [Pingback]
http://rdsblog.info/center/cache/soma.htm [Pingback]
http://warlinks.com/yabbfiles/buyxenical.htm [Pingback]
http://cuteberries.com/cbmakers/Unique/valium.htm [Pingback]
http://theorderoftime.com/game/wiki/images/buycialis.htm [Pingback]
http://smartsolutions.no/cmsimple/downloads/discountviagra.htm [Pingback]
http://cuteberries.com/cbmakers/Unique/xanax.htm [Pingback]
http://acccn.com.au/db_backup/onlinepharmacy.htm [Pingback]
http://conec.com/tmp/diazepam.htm [Pingback]
http://rightrainbow.com/archives/2004/tramadol.htm [Pingback]
http://cogiscan.com/pdf/img/buyphentermineonline.htm [Pingback]
http://rdsblog.info/center/cache/buyviagra.htm [Pingback]
http://www.google.com/search?q=gyfrlssk [Pingback]
http://jaltcall.org/blog/2005/xenical.htm [Pingback]
http://sdmlanreview.com/uploaddir/what-is-alprazolam.htm [Pingback]
http://spacecasestv.com/bboard/attachments/alprazolam.htm [Pingback]
http://cbnindia.org/1cubed/images/all-about-phentermine-online.htm [Pingback]
http://rascast.com/wwwboard/messages/39380.htm [Pingback]
http://jccc.on.ca/site/cms/dev/files/ultram.htm [Pingback]
http://nugraphic.com/docs/weight-loss-pills.htm [Pingback]
http://blog.fyrfli.net/archives/2005/zoloft.htm [Pingback]
http://blog.fyrfli.net/archives/2005/weight-watchers.htm [Pingback]
http://illegalaliens.us/merchandise/images/valium.htm [Pingback]
http://aitr.org/ev/images/soma.htm [Pingback]
http://kipaddotta.com/Web_store/Pgpfiles/ativan.htm [Pingback]
http://libertarianactivism.com/simplegroupware/bin/south-beach-diet.htm [Pingback]
http://blog.fyrfli.net/archives/2005/valium.htm [Pingback]
http://www.cdverkauf.com/banner/phentermine-adipex.htm [Pingback]
http://sdmrm.org/calendar/nexium.htm [Pingback]
http://rayhane.com/blog/ecrire/images/hoodia.htm [Pingback]
http://firstpresbyterian.org/documentation/cialis.htm [Pingback]
http://nugraphic.com/docs/zyrtec.htm [Pingback]
http://sdmrm.org/calendar/lipitor.htm [Pingback]
http://libertarianactivism.com/simplegroupware/bin/online-pharmacy.htm [Pingback]
http://risep-fiu.org/reports/old/xenical.htm [Pingback]
http://illegalaliens.us/merchandise/images/adipex.htm [Pingback]
http://rayhane.com/blog/ecrire/images/vicodin.htm [Pingback]
http://jccc.on.ca/site/cms/dev/files/buy-viagra.htm [Pingback]
http://nugraphic.com/docs/cheapviagra.htm [Pingback]
http://libertarianactivism.com/simplegroupware/bin/carisoprodol.htm [Pingback]
http://www.cbk.rotterdam.nl/openbarekunst/materiaal/old/lexapro.htm [Pingback]
http://photoblog.habibis.net/archives/animals/xenical.htm [Pingback]
http://firstpresbyterian.org/documentation/diet-pills.htm [Pingback]
http://jeunesdumaroc.com/gallerie/xanax-valium.htm [Pingback]
http://rayhane.com/blog/ecrire/images/cheap-viagra.htm [Pingback]
http://www.wwtf.at/Uploads/imgs/viagra.htm [Pingback]
http://sdmrm.org/calendar/zoloft.htm [Pingback]
http://photoblog.habibis.net/archives/animals/lexapro.htm [Pingback]
http://illegalaliens.us/merchandise/images/prozac.htm [Pingback]
http://illegalaliens.us/merchandise/images/phentermine-adipex.htm [Pingback]
http://www.google.com/search?q=cbfugudb [Pingback]
http://autismillinois.com/directory/phentermine-adipex.htm [Pingback]
http://nugraphic.com/docs/valium.htm [Pingback]
http://blog.fyrfli.net/archives/2005/pharmacy.htm [Pingback]
http://photoblog.habibis.net/archives/animals/prozac.htm [Pingback]
http://illegalaliens.us/merchandise/images/propecia.htm [Pingback]
http://www.google.com/search?q=twkjmglc [Pingback]
http://jeunesdumaroc.com/gallerie/ultram.htm [Pingback]
http://myplugins.info/itfixit/cache/phentarmine.htm [Pingback]
http://nugraphic.com/docs/fitness.htm [Pingback]
http://photoblog.habibis.net/archives/animals/lipitor.htm [Pingback]
http://photoblog.habibis.net/archives/animals/zoloft.htm [Pingback]
http://photoblog.habibis.net/archives/animals/meridia.htm [Pingback]
http://theworldiscoming.com/shop/images/phentarmine.htm [Pingback]
http://kipaddotta.com/Web_store/Pgpfiles/viagra-generic.htm [Pingback]
http://jccc.on.ca/site/cms/dev/files/phentermine.htm [Pingback]
http://mutagenix.org/forums/images/avatars/order-tramadol.htm [Pingback]
http://www.wwtf.at/Uploads/imgs/cialis.htm [Pingback]
http://sdmrm.org/calendar/hydrocodone.htm [Pingback]
http://photoblog.habibis.net/archives/animals/valium.htm [Pingback]
http://bbiverson.com/fmimages/alprazolam-online.htm [Pingback]
http://autismillinois.com/directory/ativan.htm [Pingback]
http://www.primas.at/images/bla/tramadol2.htm [Pingback]
http://www.progamerhosting.com/templates/images/paxil.htm [Pingback]
http://www.4uu.de/templates/drug.htm [Pingback]
http://www.google.com/search?q=jbsyxozw [Pingback]
http://libertarianactivism.com/simplegroupware/bin/hoodia.htm [Pingback]
http://www.primas.at/images/bla/phentermine.htm [Pingback]
http://www.4uu.de/templates/zyrtec.htm [Pingback]
http://illegalaliens.us/merchandise/images/lexapro.htm [Pingback]
http://www.google.com/search?q=xfrmkwrl [Pingback]
http://www.quilchena.com/docs/weight-loss-pills.htm [Pingback]
http://articlesubmitterpro.com/blog/maillist/prescription-drugs.htm [Pingback]
http://www.wwtf.at/Uploads/imgs/tramadol2.htm [Pingback]
http://profootballcentral.com/carp/whatisalprazolam.htm [Pingback]
http://www.futerox.com/portfloio_images/big/levitra.htm [Pingback]
http://www.progamerhosting.com/templates/images/xenical.htm [Pingback]
http://www.prosserchamber.org/generator/files/paxil.htm [Pingback]
http://www.dartmoorletterboxing.org/blog/diazepam.htm [Pingback]
http://www.seniorschoice.com/banners/xanax-valium.htm [Pingback]
http://nio.com.au/files/old/tramadol.htm [Pingback]
http://myplugins.info/itfixit/cache/tramadol.htm [Pingback]
http://autismillinois.com/directory/diet.htm [Pingback]
http://dynamic-cast.com/imwse/cheap-viagra.htm [Pingback]
http://www.progamerhosting.com/templates/images/dietpills.htm [Pingback]
http://ableworkshop.com/forum/Packages/phentermineadipex.htm [Pingback]
http://www.seniorschoice.com/banners/fitness.htm [Pingback]
http://myplugins.info/itfixit/cache/xanax.htm [Pingback]
http://dynamic-cast.com/imwse/fioricet.htm [Pingback]
http://www.4uu.de/templates/soma.htm [Pingback]
http://www.4uu.de/templates/hoodia.htm [Pingback]
http://www.google.com/search?q=dzzugzci [Pingback]
http://www.google.com/search?q=teqibflt [Pingback]
http://www.google.com/search?q=ovipbxvf [Pingback]
http://www.google.com/search?q=itfnazxo [Pingback]
"Nullable types: cambiamenti dopo la beta 2" (Claudio Brotto) [Trackback]
"Nullable structs" (Wouter's blog) [Trackback]
http://9ll-free-porn.info/82930484/chaotropic-salt-nucleases.html [Pingback]
http://9lk-free-porn.info/55566052/adult-chat.html [Pingback]
http://9lk-free-porn.info/31040076/index.html [Pingback]
http://9ll-free-porn.info/31614259/index.html [Pingback]
http://9ln-free-porn.info/25421190/index.html [Pingback]

 

RSS 2.0

Me
 

Joe Send mail to the author(s) is an architect and developer on a systems incubation project at Microsoft.

Recent

Search

Browse

Disclaimer:
The content of this site are my own personal opinions and do not represent my employer's view in anyway.

© 2013, Joe Duffy